概述
Go语言的并发模型基于CSP(Communication Sequential Process ,通信顺序过程),使用通信共享内存而不是共享内存实现通信。
channel 管道就是负责不同的 goroutine 之间的通信,可以让一个 goroutine 发送特定值到另一个 goroutine 的通信机制。
channel 作为 go 语言中特殊的数据类型,遵循先入先出的准则,保证不同协程之间的收发顺序。
定义channel
channel 是引用类型,需要进行初始化。默认为<nil>
var 名 chan 类型
var ch1 chan int
var ch2 chan bool
设置带缓存带channel
ch1 := make(chan int,4) //数字为缓冲区大小
ch2 := make(chan bool,10)
无缓冲区通道 又称同步通道
ch3 := make(chan int)
channel操作
channel 包括 发送、接受、关闭三种。其中发送 & 接受都用 <- 符号。
ch <- 10 //10入通道
ch <- 11
x := <- ch //出通道并赋值给x
<- ch //直接出 不要结果了
close(ch) //关闭通道 不是必须的
channel常见错误
nil | 空 | 非空非满 | 满 | |
发送 | 阻塞 | 阻塞 | ||
接受 | 阻塞 | 阻塞 | ||
关闭 | panic |
关闭已经关闭的channel也会引发panic