channel 是 Golang 中一个非常重要的特性,也是 Golang CSP 并发模型的一个重要体现。简单来说就是,goroutine 之间可以通过 channel 进行通信。
channel 在 Golang 如此重要,在代码中使用频率非常高,以至于不得不好奇其内部实现。本文将基于go 1.13 的源码,分析 channel 的内部实现原理。
原文链接: https://www.cyhone.com/articles/analysis-of-golang-channel/
1
littlewing 2020-02-11 14:11:35 +08:00
原来是用的 mutex ....,我还以为是 lockfree
|
2
cyhone OP 讲真我也有点吃惊,估计是 go 团队没有时间去优化这块吧。看这人的提案给出的 benchmark,性能提升有一倍左右。channel 在这块的优化还是有很大空间的
|
3
cyhone OP @littlewing 讲真我也有点吃惊,估计是 go 团队没有时间去优化这块吧。看这人的提案给出的 benchmark,性能提升有一倍左右。channel 在这块的优化还是有很大空间的
|
4
janxin 2020-02-11 18:30:56 +08:00
@cyhone github.com/golang/go/issues/8899 这个吧?应该没有一倍左右?
|
5
pythonee 2020-02-20 19:07:31 +08:00
很好的代码分析思路
|
6
Vegetable 2021-08-16 09:51:52 +08:00
挖坟了,最近代码优化的时候发现,channel 通信居然成了性能瓶颈,一搜才发现 channel 这么慢...
|