V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
The Go Programming Language
http://golang.org/
Go Playground
Go Projects
Revel Web Framework
cyhone
V2EX  ›  Go 编程语言

Golang channel 源码深度剖析

  •  
  •   cyhone · 2020-02-11 13:49:55 +08:00 · 3236 次点击
    这是一个创建于 1779 天前的主题,其中的信息可能已经有所发展或是发生改变。

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

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

    点击查看原文

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

    6 条回复    2021-08-16 09:51:52 +08:00
    littlewing
        1
    littlewing  
       2020-02-11 14:11:35 +08:00
    原来是用的 mutex ....,我还以为是 lockfree
    cyhone
        2
    cyhone  
    OP
       2020-02-11 14:19:51 +08:00
    讲真我也有点吃惊,估计是 go 团队没有时间去优化这块吧。看这人的提案给出的 benchmark,性能提升有一倍左右。channel 在这块的优化还是有很大空间的
    cyhone
        3
    cyhone  
    OP
       2020-02-11 14:20:23 +08:00
    @littlewing 讲真我也有点吃惊,估计是 go 团队没有时间去优化这块吧。看这人的提案给出的 benchmark,性能提升有一倍左右。channel 在这块的优化还是有很大空间的
    janxin
        4
    janxin  
       2020-02-11 18:30:56 +08:00
    @cyhone github.com/golang/go/issues/8899 这个吧?应该没有一倍左右?
    pythonee
        5
    pythonee  
       2020-02-20 19:07:31 +08:00
    很好的代码分析思路
    Vegetable
        6
    Vegetable  
       2021-08-16 09:51:52 +08:00
    挖坟了,最近代码优化的时候发现,channel 通信居然成了性能瓶颈,一搜才发现 channel 这么慢...
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   1010 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 24ms · UTC 20:45 · PVG 04:45 · LAX 12:45 · JFK 15:45
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.