官术网_书友最值得收藏!

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.

主站蜘蛛池模板: 内乡县| 扶余县| 前郭尔| 祥云县| 惠州市| 龙口市| 河东区| 乾安县| 高雄县| 留坝县| 内黄县| 卢湾区| 福海县| 西充县| 木兰县| 班戈县| 耒阳市| 汉沽区| 新昌县| 衡山县| 隆安县| 华容县| 凤庆县| 准格尔旗| 革吉县| 馆陶县| 吉林市| 都昌县| 巫山县| 扶绥县| 镇康县| 扶绥县| 防城港市| 崇信县| 西城区| 定西市| 兴安盟| 库尔勒市| 奎屯市| 眉山市| 广饶县|