美文网首页
go 并发编程

go 并发编程

作者: 今早上 | 来源:发表于2018-04-24 18:02 被阅读0次

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

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 是不同协成之间通讯用的!

相关文章

  • Go基础语法(九)

    Go语言并发 Go 是并发式语言,而不是并行式语言。 并发是指立即处理多个任务的能力。 Go 编程语言原生支持并发...

  • Go并发

    Go语言中的并发编程 并发是编程里面一个非常重要的概念,Go语言在语言层面天生支持并发,这也是Go语言流行的一个很...

  • 瞅一眼就会使用GO的并发编程分享

    [TOC] GO的并发编程分享 之前我们分享了网络编程,今天我们来看看GO的并发编程分享,我们先来看看他是个啥 啥...

  • day08-go.GPM

    当别人到go为什么支持高并发,或者问为什么go本身对并发编程友好?以及go与Java对比的并发对比 正确回答: 在...

  • Go语言简介

    Go语言简介 Go语言设计的初衷 针对其他语言的痛点进行设计并加入并发编程为大数据,微服务,并发而生的通用编程语言...

  • 13 Go并发编程初探

    一、Go并发编程概述 Go以并发性能强大著称,在在语言级别就原生支持,号称能实现百万级并发,并以此独步江湖,本专题...

  • Go 基础

    基础 [TOC] 特性 Go 并发编程采用CSP模型不需要锁,不需要callback并发编程 vs 并行计算 安装...

  • go 并发编程

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

  • go并发编程

    最近挖了个坑开始学习go语言,打断把其中遇到的坑都记录下来 go学习的过程中最为惊叹的就是并发编程了,我可以少掉好...

  • Go并发编程

    常见并发模型 进程 & 线程(Apache)C10K 异步非阻塞(Nginx,Libevent,NodeJS) 复...

网友评论

      本文标题:go 并发编程

      本文链接:https://www.haomeiwen.com/subject/bkojlftx.html