


在资源有限的情况下,如何最大化的利用有限的资源就是并发,提高并发

goroutine






runtime包







channel




无缓冲的channel




有缓冲的channel






通过关闭channel执行


单向channel



hello fatal error: all goroutines are asleep - deadlock!
在main goroutine线,期望从管道中获得一个数据,而这个数据必须是其他goroutine线放入管道的
但是其他goroutine线都已经执行完了(all goroutines are asleep),那么就永远不会有数据放入管道。
所以,main goroutine线在等一个永远不会来的数据,那整个程序就永远等下去了。
这显然是没有结果的,所以这个程序就说“算了吧,不坚持了,我自己自杀掉,报一个错给代码作者,我被deadlock了”
channel 是不同协成之间通讯用的!


网友评论