go 并发编程

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


goroutine



单任务执行不了下面的


遇go关键字 新建 协城



子协成会退出来不及打印后面的



输出为空


runtime包

Gosched


Goshced 让别人先


终止所在协城


打印1,3,终止协城




多任务资源竞争问题


channel


channel类型是一个引用
用管道实现顺序打印, 管道有数据就开始打印



记住,子协成的东西调用是看情况的


无缓冲的channel

记得接受者和发送者都要阻塞


有缓冲的channel


缓冲容量满了,子协成就会阻塞等待主线程读,主线程,没读一个就会丢掉,主线程丢完了就会阻塞,等待子线程塞满,两者会同事多线程进行, 只要那边读了一个,子协成就继续塞, 只要子协成塞了一个,主线程就继续读,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 是不同协成之间通讯用的!



最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • M P G M代表内核线程或工作线程,P是Go代码片段执行的上下文环境,G代表Go代码片段。一个M与一个P关联后就...
    ShutLove阅读 3,008评论 0 4
  • 基础概念 什么是进程? 进程:一个正在运行的程序一般是一个进程,一个进程可以包含多个线程每个进程都有自己的独立的地...
    ze__lin阅读 7,977评论 0 2
  • 感恩父母给予生命,抚养长大,谆谆之教导,毕生无私之奉献。愿天下父母健康平安快乐! 感恩天气晴好,旭日笑意盈盈般冉冉...
    Holly妮阅读 877评论 0 0
  • 我们都 ,我们都会在一起了。我的人家都市的话。我的人家都市报报道称。我们的心理准备金率,我们的心理准备金率, 好咯...
    haolianxue阅读 1,170评论 0 0
  • 1.创建界面 2.获取本地数据这里的字符串中的内容就是plist文件的名字 3.设置了代理那么就要去实现协议方法,...
    Wen_Wei_Yen阅读 2,784评论 0 0