Golang channel 源码深度剖析

2020-02-11 13:49:55 +08:00
 cyhone

channel 是 Golang 中一个非常重要的特性,也是 Golang CSP 并发模型的一个重要体现。简单来说就是,goroutine 之间可以通过 channel 进行通信。

channel 在 Golang 如此重要,在代码中使用频率非常高,以至于不得不好奇其内部实现。本文将基于go 1.13 的源码,分析 channel 的内部实现原理。

点击查看原文

原文链接: https://www.cyhone.com/articles/analysis-of-golang-channel/

3219 次点击
所在节点    Go 编程语言
6 条回复
littlewing
2020-02-11 14:11:35 +08:00
原来是用的 mutex ....,我还以为是 lockfree
cyhone
2020-02-11 14:19:51 +08:00
讲真我也有点吃惊,估计是 go 团队没有时间去优化这块吧。看这人的提案给出的 benchmark,性能提升有一倍左右。channel 在这块的优化还是有很大空间的
cyhone
2020-02-11 14:20:23 +08:00
@littlewing 讲真我也有点吃惊,估计是 go 团队没有时间去优化这块吧。看这人的提案给出的 benchmark,性能提升有一倍左右。channel 在这块的优化还是有很大空间的
janxin
2020-02-11 18:30:56 +08:00
@cyhone github.com/golang/go/issues/8899 这个吧?应该没有一倍左右?
pythonee
2020-02-20 19:07:31 +08:00
很好的代码分析思路
Vegetable
2021-08-16 09:51:52 +08:00
挖坟了,最近代码优化的时候发现,channel 通信居然成了性能瓶颈,一搜才发现 channel 这么慢...

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/643710

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX