Go并发编程之三

一、前言

前一篇讲了Go中通道的概念,只讲了无缓存通道,这一篇我们来了解一下有缓存通道以及它与无缓存通道一些区别。

二、有缓存通道

  • **无缓存通道:**如果通道数据没有被接收,发送方会被阻塞,相当于同步。

  • 有缓存通道:发送数据到通道会被放在队列中,接收时从队列删除数据,当通道满的时候发送方才会阻塞,如果通道是空的则接收方也会被阻塞,很像FIFO先进先出的队列,发送方和接收方可以认为是异步解耦的。

创建有缓存通道

ch := make(chan string ,10)

ch := make(chan string ,1) 当设置为1创建的也是有缓存通道,而非无缓存通道。

ch := make(chan string ,0) 相当于 ch := make(chan string) 创建的是无缓存通道

三、例子

注:获取goroutine的编号,现在官方不提供让你直接获取goroutine ID,也不建议你使用,但还是可以通过stack中获取到。

我们通过下面例子来看有缓存和无缓存通道的实际区别

执行结果:

注:创建容量为2的缓存通道,子goroutine向通道写入5条数据,主goroutine从通道读出两条数据,查看执行结果往通道写数据执行了4次,另外1次没有执行,说明往通道写的时候阻塞了。往通道写4条数据,其中有两条数据被主goroutine读取了,然后通道中还剩余2条数据,这和通道容量大小一致。

如果将通道设置为无缓存通道 size :=0

执行结果:

注:子goroutine只往通道写了两条数据,因为主goroutine读取了2条,另外3条写入时就全部都阻塞了。

特别说明

子goroutine写入阻塞,主goroutine不一定阻塞,为了演示效果代码最后加了一个死循环for{},如果没有加for{},当有缓存通道还有容量空间却不一定能往里放,因为有可能主goroutine已经执行完了,然后整个进程就Over了,子协程生命依赖于主协程这个概念Go并发编程第一篇就有介绍,但今天在写这个代码时没有意识到,折腾了好一会才发现问题,然后在朋友建议了加了空for{}。

相关推荐
fsnine3 分钟前
Python图形化界面——pyqt5教程
开发语言·python·qt
虫小宝3 分钟前
Java分布式架构下的电商返利APP技术选型与架构设计实践
java·分布式·架构
007php0077 分钟前
百度面试题解析:Zookeeper、ArrayList、生产者消费者模型及多线程(二)
java·分布式·zookeeper·云原生·职场和发展·eureka·java-zookeeper
嵌入式-老费11 分钟前
Easyx图形库应用(和lua结合使用)
开发语言·lua
AsiaLYF12 分钟前
kotlin中MutableStateFlow和MutableSharedFlow的区别是什么?
android·开发语言·kotlin
Asuncion00723 分钟前
Docker核心揭秘:轻量级虚拟化的革命
服务器·开发语言·docker·云原生
4Forsee34 分钟前
【Android】浅析 Android 的 IPC 跨进程通信机制
android·java
来旺1 小时前
互联网大厂Java面试全解析及三轮问答专项
java·数据库·spring boot·安全·缓存·微服务·面试
Json____1 小时前
使用node Express 框架框架开发一个前后端分离的二手交易平台项目。
java·前端·express
since �1 小时前
前端转Java,从0到1学习教程
java·前端·学习