Go语言中channel是goroutine间通信的核心机制,通过数据传递实现同步与协作。使用make创建通道时需指定数据类型和缓冲大小:无缓冲channel(如ch := make(chan int))实现同步阻塞通信,发送与接收必须配对完成;有缓冲channel(如ch := make(chan int, 2))提供异步通信能力,在缓冲未满或未空时不会阻塞。基本操作包括发送(ch

理解Go语言中的channel,核心在于掌握它作为goroutine间通信管道的机制。它不是共享内存,而是通过传递数据来实现同步与协作,这正是Go并发编程的精髓所在。
创建和基本操作
一个channel必须先用make函数创建才能使用,声明时需指定传输的数据类型。根据是否带缓冲区,分为两种:
-
无缓冲channel:创建时未指定大小,如
ch := make(chan int)。它的特点是同步阻塞,发送方会一直等待,直到有接收方准备好从通道读取数据,反之亦然。这种严格的配对确保了goroutine间的同步。 -
有缓冲channel:创建时指定了缓冲区大小,如
ch := make(chan int, 2)。它像一个小型队列,发送操作在缓冲区满之前不会阻塞,接收操作在缓冲区空之前也不会阻塞,从而实现了goroutine间的异步通信。
基本操作有三种:
发送 使用 操作符,写法为 ch ;
接收 同样用 ,可以赋值给变量 value := ,也可以忽略结果 ;
关闭 用 close(ch) 函数,表示不再有数据发送,但已有的数据仍可被接收。
单向通道与最佳实践
为了代码清晰和安全,Go支持单向通道,用于限制函数对通道的操作权限。
- 只发送通道 (chanfunc send(out chan,该函数只能往通道里发送数据,无法从中接收,防止误用。
- 只接收通道 (func receive(in ,该函数只能从通道接收数据,不能发送。
一个重要的习惯是,通常由负责发送数据的goroutine来关闭通道,而接收方则通过循环或检查返回值来安全地处理可能的关闭状态。向一个已关闭的通道发送数据会引发panic,而从已关闭的通道接收数据,会得到对应类型的零值。
立即学习“go语言免费学习笔记(深入)”;
多路复用与超时控制
当需要同时处理多个通道时,select语句是关键工具,它能监听多个通道的操作,哪个通道就绪就执行哪个case。
- 每个
case都是一个通道的发送或接收操作。 - 如果有多个通道同时就绪,
select会随机选择一个执行,避免了饥饿问题。 - 加入
default分支可以实现非阻塞操作,当没有通道就绪时立即执行default里的逻辑。
结合time.After(),可以在select中轻松实现超时控制,防止程序在某个通道上无限期等待,这对于构建健壮的网络服务至关重要。
基本上就这些。










