先看看无缓存管道的例子:
a := make(chan bool)
go func() {
log.Println("goroutine")
<-a
}()
a <- true
这里主协程会等待子协程执行完,但是如果把第一行改成 a := make(chan bool, 1),那么主协程写完消息直接退出了,子协程没有机会执行(只有一个 cpu 时)。但是改成如下子协程又可以执行了:
a := make(chan bool, 1)
go func() {
log.Println("goroutine")
<-a
}()
a <- true
a <- true
a := make(chan bool, 1)
go func() {
close(a)
}()
for {
select {
case _, ok := <-a:
log.Println(ok)
}
}
而用 for range 是不能获取 close 信号的,如下:
a := make(chan bool, 1)
go func() {
a <- true
close(a)
}()
for {
for v := range a {
log.Println(v)
}
}
这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。
V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。
V2EX is a community of developers, designers and creative people.