go 并发编程

go 并发编程_第1张图片
go 并发编程_第2张图片
go 并发编程_第3张图片

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


go 并发编程_第4张图片

goroutine



go 并发编程_第5张图片
go 并发编程_第6张图片
单任务执行不了下面的


go 并发编程_第7张图片
go 并发编程_第8张图片
遇go关键字 新建 协城



go 并发编程_第9张图片
子协成会退出来不及打印后面的



go 并发编程_第10张图片
输出为空


runtime包

go 并发编程_第11张图片
Gosched


go 并发编程_第12张图片
Goshced 让别人先


终止所在协城


go 并发编程_第13张图片
打印1,3,终止协城




go 并发编程_第14张图片
go 并发编程_第15张图片
多任务资源竞争问题


channel


go 并发编程_第16张图片
go 并发编程_第17张图片
channel类型是一个引用
go 并发编程_第18张图片
用管道实现顺序打印, 管道有数据就开始打印



go 并发编程_第19张图片
记住,子协成的东西调用是看情况的


无缓冲的channel

go 并发编程_第20张图片
go 并发编程_第21张图片
go 并发编程_第22张图片
go 并发编程_第23张图片
记得接受者和发送者都要阻塞


有缓冲的channel


go 并发编程_第24张图片
go 并发编程_第25张图片
go 并发编程_第26张图片
go 并发编程_第27张图片
缓冲容量满了,子协成就会阻塞等待主线程读,主线程,没读一个就会丢掉,主线程丢完了就会阻塞,等待子线程塞满,两者会同事多线程进行, 只要那边读了一个,子协成就继续塞, 只要子协成塞了一个,主线程就继续读,channel是引用的!


go 并发编程_第28张图片
结果
go 并发编程_第29张图片


通过关闭channel执行


go 并发编程_第30张图片
这个是无缓冲的channel, 两个协成同事进行,一检测到他塞入,就立马读出


go 并发编程_第31张图片


单向channel


go 并发编程_第32张图片
go 并发编程_第33张图片
go 并发编程_第34张图片
单向channel参数传递


hello fatal error: all goroutines are asleep - deadlock!

在main goroutine线,期望从管道中获得一个数据,而这个数据必须是其他goroutine线放入管道的 

但是其他goroutine线都已经执行完了(all goroutines are asleep),那么就永远不会有数据放入管道。 

所以,main goroutine线在等一个永远不会来的数据,那整个程序就永远等下去了。 

这显然是没有结果的,所以这个程序就说“算了吧,不坚持了,我自己自杀掉,报一个错给代码作者,我被deadlock了”


channel 是不同协成之间通讯用的!



go 并发编程_第35张图片
go 并发编程_第36张图片

你可能感兴趣的:(go 并发编程)