Golang Channel select

前端之家收集整理的这篇文章主要介绍了Golang Channel select前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

Golang 中对Channel 的支持添加了select关键字,

Golang中基于Channel select的实现由监控、定时器等示例参考http://www.jb51.cc/article/p-tuubrzwx-bma.html

执行流程有点类似switch case,case 后只能接channel输出,可以用变量接收:num:=<-ch

若所有的case后的channel都没有输出,则继续循坏等待,若所有的case后的channel均有输出,则随机选择一个case执行。


但是与for循坏有很大区别,应该是加入了sleep机制,不会占满cpu,下面程序监测程序,与for循环做对比。

1 package main

2
3 import(
4 "time"
5 )
6 var quit chan int = make(chan int)
7 func loop(ch chan int) {
8 select {
9 case <-ch:
10 case <-time.After(time.Duration(20)*time.Second): quit <-0
11 }
12 }
13 func gofor(ch chan int){
14 for{
15 _,ok:= <-ch;
16 if ok {
17 break
18 }
19 }
20 }
21 func main () {
22 ch := make(chan int)
23 /*
24 close(ch)
25 loop(ch)
26 <-quit
27 */
28 go gofor(ch)
29 time.Sleep(10*time.Second)
30 ch<-0
31 }

结果分析:

执行Channel select:cpu占用0.0%


执行for循环:cpu占用101%

猜你在找的Go相关文章