go中的select提供了一种方式来处理多个channels,select语句满足如下条件
- 每个channel的值都会被计算
- 如果没有channel有产出的话,会阻塞直到一个channel产出
- 如果多个channel有产出的话,会假随机(pseudo-randomly)的选择一个产出
- 在有default语句的情况下,没有channel准备好的时候,会立即执行default的语句
下面有一个实例,源码中对boring返回结果的注释(第一行末尾的注释)直译是返回一个只接受string类型的channel。但是个人觉得翻译为返回的是一个只读的string类型的channel更好,因为后续的对c的操作,都只能从c中读取string。
func boring(msg string) <-chan string { // Returns receive-only channel of strings.
c := make(chan string)
go func() { // We launch the goroutine from inside the function.
for i := 0; ; i++ {
c <- fmt.Sprintf("%s %d", msg, i)
time.Sleep(time.Duration(rand.Intn(1e3)) * time.Millisecond)
}
}()
return c // Return the channel to the caller.
}
func fanIn(input1, input2 <-chan string) <-chan string {
c := make(chan string)
go func() {