内容简介:总结一下昨天这里贴出一篇关于golang流行开源项目涉及到并发bug的论文上图可以看到,golang主流的开源项目用到的并发原语的比例。主要集中在Mutex和channel,所以这应该是我们学习的重点部分。
总结一下昨天 鸟窝 在《Go 同步和并发设计模式》 分享的 golang 并发开发相关的知识。主要分为四个部分,同步原语,分布式同步原语,channel,内存模型。这里主要从初学者角度,以鸟窝的ppt为大纲,来梳理一下常用的功能,用法和代码实现。
前沿背景
这里贴出一篇关于golang流行开源项目涉及到并发bug的论文
image.png
上图可以看到,golang主流的开源项目用到的并发原语的比例。主要集中在Mutex和channel,所以这应该是我们学习的重点部分。
同步原语
Mutex
结构定义
// A Mutex must not be copied after first use. type Mutex struct { state int32 sema uint32 }
注释可以看到Mutex是不能复制的。
RWMutex
Cond
WaitGroup
Once
Pool
sync.Map
context.Context
ReentrantLock
Semaphore
SingleFlight
ErrGroup
SpinLock
atomic 包
分布式同步原语
Channel
内存模型 happens before
以上所述就是小编给大家介绍的《golang 并发原语[草稿]》,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对 码农网 的支持!
猜你喜欢:- 机器学习中的数学,这是一份新鲜出炉的热门草稿
- Golang 并发编程与同步原语
- java – 如何将原语int传递给我的AsyncTask?
- 无需Native Code的RCE——IE8中的写入原语利用
- golang的相关问题(返回局部变量指针、分配原语、init、值与引用、接口、内建函数等等)
本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。