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

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.

主站蜘蛛池模板: 乐陵市| 普定县| 井研县| 镇赉县| 从江县| 宽城| 建湖县| 贵溪市| 平和县| 安庆市| 平阳县| 清徐县| 肇源县| 西峡县| 临颍县| 黎城县| 新闻| 彰化县| 香河县| 静宁县| 金塔县| 磐安县| 行唐县| 龙陵县| 营山县| 梅河口市| 瓦房店市| 江西省| 西盟| 明光市| 新干县| 泾源县| 海淀区| 汶上县| 中江县| 广河县| 澎湖县| 曲阳县| 萍乡市| 赤壁市| 福泉市|