go 实现生产者与消费者模型,如何判断channel中数据已全部消费?
code
package main
import (
"fmt"
)
var c = make(chan int, 50)
var count = 0
func main() {
for i := 0; i < 5; i++ {
go consumer(i)
}
for i := 0; i < 1000; i++ {
c <- i
}
/** here **/
fmt.Println(count)
}
func consumer(index int) {
for target := range c {
fmt.Printf("no.%d:%d\n", index, target)
count++
}
}
请问代码中注释处,如何才能确保c中的数据已经全部被消费?(默认time.Sleep()无法保证,不能使用)
如果不能确保的话,那么主线程会提前退出,部分数据就会被抛弃了。
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(2)
这种可以使用sync里的WaitGroup工具来做等待,也可以单独开个channel来等待。如果只是想单纯的保证goroutine全部执行完毕再退出main,可以定义个相同数量buffer的channel,每个goroutine执行结束后就写入这个channel,而main只要消费等待channel就可以达到阻塞的目的了。
类似这样
参考http://blog.csdn.net/kjfcpua/...已解决,使用WaitGroup就解决了