字面启动goroutine和loop控制流里启动goroutine的执行效果为什么不一样

具体的代码我放在了play.golang

代码1: http://play.golang.org/p/HcwPzI4S5J

代码2: http://play.golang.org/p/fvDjWlJiub

按理说,两者应该有一样的结果,但实际是代码一会正常执行,而代码二会死锁。

为什么会死锁呢?两片代码的区别仅仅在于如何启动goroutine的地方.

代码的意图:

把流入三个分支信道的数据复合流入到一个信道,然后从这个总输出信道取数据。


追加: 再观察下这段代码 http://play.golang.org/p/WcdR9Cm5JD

不同之处是用另一种方式来迭代.

报的错误不是deadlock而是runtime error了!

回答:

http://play.golang.org/p/HR9Soc7TL8

改了下,看看是这样不

下面的出看《Golang中常见的坑与编码模式》

请输入图片描述

请输入图片描述

请输入图片描述
请输入图片描述

加个slide的地址:

https://speakerdeck.com/lidashuang/golangchang-jian-de-keng-he-bian-cheng-mo-shi

回答:

for i := range c能够不断读取channel里面的数据,直到该channel被显示关闭close(channel)。 通过语法v, ok := <- ch测试channel是否被关闭。如果ok返回false,那么说明channel已经没有任何数据并且已经被关闭。

以上是 字面启动goroutine和loop控制流里启动goroutine的执行效果为什么不一样 的全部内容, 来源链接: utcz.com/p/183250.html

回到顶部