分享
non-blocking channel options _ golang
jackkiexu · · 2300 次点击 · · 开始浏览这是一个创建于 的文章,其中的信息可能已经有所发展或是发生改变。
Basic sends and receives on channels are blocking. However, we can use select with a default clause to implement non-blocking sends, receives, and even non-blocking multi-way selects
package main import ( "fmt" ) func main() { message := make(chan string) signals := make(chan bool) select { case msg := <-message: fmt.Println("received message", msg) default: fmt.Println("no message received") } msg := "hi" select { case message <- msg: fmt.Println("sent message", msg) default: fmt.Println("no message sent") } select { case msg := <-message: fmt.Println("received message", msg) case sig := <-signals: fmt.Println("received signal", sig) default: fmt.Println("no activity") } }
no message received
no message sent
no activity
总结 :
1:....
有疑问加站长微信联系(非本文作者)
入群交流(和以上内容无关):加入Go大咖交流群,或添加微信:liuxiaoyan-s 备注:入群;或加QQ群:692541889
关注微信2300 次点击
上一篇:go学习笔记(01)- 简介
下一篇:golang学习之指针、内存分配
添加一条新回复
(您需要 后才能回复 没有账号 ?)
- 请尽量让自己的回复能够对别人有帮助
- 支持 Markdown 格式, **粗体**、~~删除线~~、
`单行代码` - 支持 @ 本站用户;支持表情(输入 : 提示),见 Emoji cheat sheet
- 图片支持拖拽、截图粘贴等方式上传
收入到我管理的专栏 新建专栏
Basic sends and receives on channels are blocking. However, we can use select with a default clause to implement non-blocking sends, receives, and even non-blocking multi-way selects
package main import ( "fmt" ) func main() { message := make(chan string) signals := make(chan bool) select { case msg := <-message: fmt.Println("received message", msg) default: fmt.Println("no message received") } msg := "hi" select { case message <- msg: fmt.Println("sent message", msg) default: fmt.Println("no message sent") } select { case msg := <-message: fmt.Println("received message", msg) case sig := <-signals: fmt.Println("received signal", sig) default: fmt.Println("no activity") } }
no message received
no message sent
no activity
总结 :
1:....