select:
作用:用来监听channel上的数据流动方向。读和写
用法:参考switch case语句。但是case后面必须是IO操作,不能任意写判别表达式。
注意事项:
1.监听的case中,没有满足监听条件,阻塞。
2.监听的case中,有多个满足监听的条件,任选一个执行。
3.可以使用default来处理所有case都不满足监听条件的状况。但通常不使用(会产生忙轮询)
4.select自身不带有循环机制,需借助外层for来循环监听。
5.break只能跳出select的一个case选项,不能跳出for循环,如想跳出for循环,使用return。类似switch中的用法。
select实现斐波那契(fibonacci)数列:
1 1 2 3 5 8 13 21 34 55 89
package main
import (
"fmt"
"runtime"
)
//子协程作为消费者,从channel拿数据
func fibonacci(ch chan int,quit chan bool) {
for {
select {
case num := <-ch:
fmt.Printf("%d\t",num)
case <-quit:
runtime.Goexit()//等效于return
}
}
}
func main() {
ch :=make(chan int)
quit :=make(chan bool)
go fibonacci(ch,quit)//调用子协程
//主协程作为生产者,往channel中写数据
x,y :=1,1
for i:=0;i<20;i++ {
ch <-x
x,y = y,x+y
}
quit <-true
}
执行结果: