无缓冲通道中处理不过来数据的后果
对于两个 goroutine,一个负责发送数据,另一个负责接收并处理数据,如果处理数据的速度远远落后于发送数据的速度,那么发送数据的 goroutine 会发生什么?
无缓冲通道不同于有缓冲通道,它没有存储容量,数据只能在发送方和接收方准备好时传输。在这种情况下,如果处理数据的 goroutine 速度太慢,发送数据的 goroutine 就会被阻塞,直到接收方准备好处理数据。
由于无缓冲通道没有缓冲区,因此不会丢弃数据。相反,发送数据 goroutine 会一直等待接收方处理数据,直到缓冲区有空间容纳新的数据。
这个问题的处理方法取决于具体业务逻辑。如果处理数据需要大量时间,可以考虑使用有缓冲通道,以避免发送数据 goroutine 被阻塞。