【发布时间】:2017-07-07 12:25:37
【问题描述】:
很抱歉这个菜鸟问题,但我很难理解 go 的并发部分。基本上,下面的这个程序是我正在编写的一个更大的程序的简化版本,因此我想保持类似于下面的结构。
基本上,我不想等待 4 秒,而是想使用无缓冲通道并发运行 addCount(..),当 int_slice 中的所有元素都已处理完毕后,我想对它们进行另一次操作。然而,这个程序以 "panic: close of closed channel" 结束,如果我删除通道的关闭,我会得到我期望的输出,但它会恐慌:"fatal错误:所有 goroutine 都处于休眠状态 - 死锁”
在这种情况下如何正确实现并发部分?
提前致谢!
package main
import (
"fmt"
"time"
)
func addCount(num int, counter chan<- int) {
time.Sleep(time.Second * 2)
counter <- num * 2
}
func main() {
counter := make(chan int)
int_slice := []int{2, 4}
for _, item := range int_slice {
go addCount(item, counter)
close(counter)
}
for item := range counter {
fmt.Println(item)
}
}
【问题讨论】:
-
在这里您想在您的频道上保存多个值。您必须为您的数据提供一些存储空间。
标签: go concurrency