我阅读了 select 语句及其执行步骤,但我并不完全理解这里发生了什么。
我创建了两个扇入函数示例(来自Go Concurrency Patterns talk)
第一个:
select {
case value := <-g1:
c <- value
case value := <-g2:
c <- value
}
按预期从每个通道打印(每个通道都有自己的计数器):
Bob : 0
Alice: 0
Bob : 1
Alice: 1
Bob : 2
Alice: 2
Alice: 3
Alice: 4
Bob : 3
Alice: 5
第二个:
select {
case c <- <-g1:
case c <- <-g2:
}
它随机选择一个通道并丢弃另一个通道的值:
Bob : 0
Alice: 1
Alice: 2
Alice: 3
Bob : 4
Alice: 5
Bob : 6
Alice: 7
Alice: 8
Bob : 9
更新:在写这个问题时,我认为第二个select 等于:
var v string
select {
case v = <-g1:
case v = <-g2:
c <- v
}
但我错了,因为这个总是从第二个通道打印(正如 switch like 语句所预期的那样,因为 select 语句中没有fallthrough):
Bob : 0
Bob : 1
Bob : 2
Bob : 3
Bob : 4
Bob : 5
Bob : 6
Bob : 7
Bob : 8
Bob : 9
有人明白为什么我的第二个例子会创建一个序列吗?
四季花海
相关分类