最近自学Go语言,看到go并发和channel通信了,还没深入channel通信,就先写个简单例子了解一下,代码如下:
```go
package main
import "fmt"
func Add(index int, ch chan int) {
fmt.Println(index, ":Before Counting")
ch <- 1
fmt.Println(index, ":After Counting")
}
func main() {
chs := make([]chan int, 10)
for i := 0; i < 10; i++ {
chs[i] = make(chan int)
go Add(i, chs[i])
}
for i, ch := range chs {
fmt.Println("第", i, "个ch输出", <-ch)
}
}
```
运行结果如下:
0 :Before Counting
0 :After Counting
1 :Before Counting
2 :Before Counting
3 :Before Counting
4 :Before Counting
5 :Before Counting
6 :Before Counting
7 :Before Counting
8 :Before Counting
9 :Before Counting
第 0 个ch输出 1
第 1 个ch输出 1
第 2 个ch输出 1
第 3 个ch输出 1
第 4 个ch输出 1
第 5 个ch输出 1
第 6 个ch输出 1
第 7 个ch输出 1
第 8 个ch输出 1
第 9 个ch输出 1
请问:为什么第一个goroutine的before和after都输出了?为什么后面的都只输出了before,而且没有after的输出?
你的结果是正常的,没有异常:
1)第一个goroutine的before和after都输出了, 那是凑巧了,也可能不输出 after没有定论; 当然也可能第二个goroutine的before和after都输出了,谁知道。
2)后面的都只输出了before,而且没有after,那是因为 main()退出了。
#8
更多评论
协程还没输出 after 的时候主程序就退出了,在代码末尾加上 time.Sleep(5 * time.Second) 就可以看到了,不过正确的方法还是加上同步,参考 http://golang.org/pkg/sync/#WaitGroup
#1