什么是 Channels ?
Channels 是 Goroutines 之间通信的通道,用于多个 Goroutine 之间的消息传递和协作。在很多编程语言中,线程之间通信和协作的方式往往是通过共享变量(共享内存)来实现的,这种编程方式需要程序员对于共享变量的读写进行保护,比如加锁,从而保证线程之间的正确协作。Go 语言提倡另一种方式 – 通过通信来共享内存,Goroutine 之间共享的值通过 channels 进行传递,Go 语言保证同一时刻只有一个 Goroutine 可以访问 channels 中的值,从设计上就避免了数据竞争的出现。
Do not communicate by sharing memory; instead, share memory by communicating.
channels 中消息的流动方向
channels 可以是单向的或者双向的:
- 单向的 channel 只能进行 send 或者 receive 操作。单向的 channel 用于函数参数声明,表明函数调用时传递的 channel 用于 send 或者 receive 操作
- 双向的 channel 可以执行 send 和 receive 操作
channels 的状态
channels 有三种状态,不同状态下的 send 和 receive 操作有不同的行为:
1. nil 状态
一个刚声明的 channel 处于nil
状态
- send 和 receive 操作都会被阻塞