selectchannel
select{
case <- ch1:
// do something
case i := <- ch2
// use i do something
default:
// ...
}
switchselect
- code-1
func main() {
ch := make(chan int)
for i := 0; i < 10; i++{
select {
case ch <- i:
case x := <- ch:
fmt.Println(x)
}
}
}
channel
deadlock
那么我们稍微修改一下这个代码,
ch := make(chan int, 1)
1
0
2
4
6
8
1casechannel
在第一次进入循环的时候,i为0,进入到select中,开始由上向下来发现哪一个case可以执行,当计算表达式
ch <- i,也就是向管道写入数据的时候,因为这个管道现在有缓冲,那么在向管道写完数据之后,此时的case便执行完成,然后就跳出select,开始进行下一次的循环,当i=1的时候(现在这个管道里面的数据是0),再次进入select中,此时还是开始计算ch <- i 表达式,但是现在管道里面是有数据的,再次向管道中写入数据,那么会使该发送操作阻塞,此时该case便无法再执行,那么select将会继续向下执行下一个case,在下一个case中,有一个管道的接收操作x := <- ch,在这里管道里有之前第一次循环的时候放入的0这个数据,那么在这里就会将管道的数据赋值给x,从而打印出第一个数据0,那么后面的数据就和之前的过程是一样的了。
deadlock
channelbuffer channelgoroutine
goroutine