1 go的select配合chan 使用使用方式和switch 相似.要求是case 后面的操作必须是chan的读取
//下面这个select会选择default.因为前两个都走不通
//如果没有default 会一直循环case从上到下知道有通道 能读写.
var ch1 chan int
var ch2 chan int
var ch3 []chan int =[] chan int{ch1,ch2}
var numbers=[]int{1,2,3,4,5}
func main(){
select {
case getchan(0)<-getnumber(0): //向未被初始化的通道发送数据会造成当前的g永久的阻塞
fmt.Println("哈哈")
case getchan(1)<-getnumber(1):
fmt.Println("呵呵")
default: //顺序执行前两个case 但是通道都阻塞了选择default
fmt.Println("给我打")
}
}
func getnumber(i int )int{
fmt.Printf("get number [%d]\n",i)
return numbers[i]
}
func getchan( i int ) chan int {
fmt.Printf("get chan [%d]\n",i)
return ch3[i]
}
2 select往往写在一个g中 配合for使用.使用select打印斐波拉切
func Fib(ch chan<- int ,quit <-chan struct{}){
x,y:=1,1
loop:
for {
select {
case ch<-x: //可以写入,写入死循环继续select 阻塞,等待另外的协程读取
x,y=y,x+y
case <-quit:
fmt.Println("ch阻塞了,改退出了")
break loop
}
}
fmt.Println("唔 哈哈哈")
}
func main(){
ch1:=make(chan int)
ch2:=make(chan struct{})
//计算前几个斐波拉切
go func() {
for i:=0;i<8;i++{
num:=<-ch1 //第一次进入循环读取(没有),阻塞只能走Fib
fmt.Println(num)
}
ch2<-struct {}{}
}()
Fib(ch1,ch2)
}
有疑问加站长微信联系(非本文作者))