应优先使用 channel 而非共享内存加锁,因 Go 哲学主张“通过通信共享内存”;unbuffered channel 天然阻塞同步,适用于等待完成或请求-响应场景。
在 Go 语言中,协程(goroutine)间的数据传递应**优先使用 channel**,而非共享内存加锁。这是 Go 的设计哲学——“不要通过共享内存来通信,而应通过通信来共享内存”。channel 天然支持同步、阻塞、缓冲控制和类型安全,是实现 goroutine 安全协作的核心机制。
无缓冲 channel 在发送和接收操作上必须配对阻塞,天然适合“等待完成”或“请求-响应”场景。
示例:
go func(ch chan int) {带
缓冲的 channel 允许发送端在缓冲未满时不阻塞,接收端在缓冲非空时不阻塞,适用于异步处理、任务队列、背压控制等场景。
range 配合 close() 实现消费者循环示例:
jobs := make(chan int, 10)channel 使用不当极易引发死锁(fatal error: all goroutines are asleep)或 goroutine 泄漏。
for v := range ch 或 ok 判断是否关闭安全接收写法:
if val, ok := fmt.Println("received:", val)虽然用 sync.Mutex 保护共享变量也能实现数据传递,但会带来明显问题:
channel 是 Go 对 CSP(Communicating Sequential Processes)模型的实践,它让并发逻辑更清晰、更健壮、更易测试。