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

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.

主站蜘蛛池模板: 内乡县| 明星| 沅江市| 许昌市| 科尔| 建宁县| 龙胜| 龙井市| 临夏市| 深州市| 四子王旗| 曲周县| 华蓥市| 平阴县| 全椒县| 香河县| 阿拉尔市| 黄石市| 雅江县| 荆门市| 海伦市| 和静县| 苍梧县| 辉南县| 漠河县| 荃湾区| 察雅县| 古田县| 平泉县| 松滋市| 老河口市| 浦东新区| 霍林郭勒市| 福清市| 南京市| 定安县| 河池市| 松阳县| 临江市| 贵南县| 平原县|