概念簡介
常規的通過通道發送和接收數據是阻塞的。然而,我們可以
使用帶一個 `default` 子句的 `select` 來實現非阻塞 的
發送、接收,甚至是非阻塞的多路 `select`。
例程代碼
package main
import "fmt"
func main() {
messages := make(chan string)
signals := make(chan bool)
// 這裏是一個非阻塞接收的例子。如果在 `messages` 中
// 存在,然後 `select` 將這個值帶入 `<-messages` `case`
// 中。如果不是,就直接到 `default` 分支中。
select {
case msg := <-messages:
fmt.Println("received message", msg)
default:
fmt.Println("no message received")
}
// 一個非阻塞發送的實現方法和上麵一樣。
msg := "hi"
select {
case messages <- msg:
fmt.Println("sent message", msg)
default:
fmt.Println("no message sent")
}
// 我們可以在 `default` 前使用多個 `case` 子句來實現
// 一個多路的非阻塞的選擇器。這裏我們試圖在 `messages`
// 和 `signals` 上同時使用非阻塞的接收操作。
select {
case msg := <-messages:
fmt.Println("received message", msg)
case sig := <-signals:
fmt.Println("received signal", sig)
default:
fmt.Println("no activity")
}
}
執行&輸出
$ go run non-blocking-channel-operations.go
no message received
no message sent
no activity
課程導航
學習上一篇:Go語言教程:超時處理 學習下一篇:Go語言教程:通道的關閉
相關資料
本例程github源代碼:https://github.com/xg-wang/gobyexample/tree/master/examples/non-blocking-channel-operations