- Hands-On Full Stack Development with Go
- Mina Andrawos
- 398字
- 2021-07-02 12:33:34
The select statement
The select statement is an important construct in Go. It allows you to control multiple channels at the same time. With select, you can send or receive values to different channels, and then execute code based on the channel that unblocks the first.
This will be best explained by an example; let's take a look at the following piece of code:
select {
case i := <-ch:
fmt.Println("Received value:", i)
case <-time.After(1 * time.Second):
fmt.Println("timed out")
}
In the preceding example, we utilized the select statement to exercise control over two different channels. The first channel is called ch, which we attempted to receive a value from. In comparison, the second channel is produced from the time.After() function. The time.After() function is very popular in Go, and especially in select statements. The function generates a channel that only receives a value after the specified timeout, in effect producing a blocking channel for a predefined period of time. You can use time.After() in your code with the select statement in cases where you would want to timeout a receive or a send operation on another channel.
Here is another example of sending a select statement with a timeout channel, but this time it's a combination of receive and send operations:
select {
case i := <-ch1:
fmt.Println("Received value on channel ch1:", i)
case ch2 <- 10:
fmt.Println("Sent value of 10 to channel ch2")
case <-time.After(1 * time.Second):
fmt.Println("timed out")
}
The preceding code will synchronize between three channels: ch1, ch2, and the time.After() channel. The select statement will wait on those three channels and then, depending on whichever channel finishes first, the appropriate select case will be executed.
The select statement also supports the default case. The default case will execute immediately if none of the channels are ready; here is an example:
select {
case i := <-ch1:
fmt.Println("Received value on channel ch1:", i)
case ch2 <- 10:
fmt.Println("Sent value of 10 to channel ch2")
default:
fmt.Println("No channel is ready")
}
In the preceding code, if both ch1 and ch2 are blocked by time, the select statement is executed, and then the default case will trigger.
If multiple channels finish at the same time while being controlled by a select statement, the channel case to be executed is picked at random.
Let's take a look at the sync package in the next section.
- UI設計基礎培訓教程
- 程序員面試筆試寶典(第3版)
- The Modern C++ Challenge
- Python入門很簡單
- Arduino by Example
- Mastering QGIS
- 區塊鏈架構與實現:Cosmos詳解
- 算法精粹:經典計算機科學問題的Python實現
- Monitoring Elasticsearch
- Yocto for Raspberry Pi
- Mastering Linux Network Administration
- 自然語言處理Python進階
- 深入淺出Serverless:技術原理與應用實踐
- Unity 2018 Augmented Reality Projects
- Hands-On Neural Network Programming with C#