运维.售后
论坛
潜水/灌水快乐,沉淀知识,认识更多同行。
ToB圈子
加入IT圈,遇到更多同好之人。
朋友圈
看朋友圈动态,了解ToB世界。
博客
Blog
ToB门户
了解全球最新的ToB事件
排行榜
Ranklist
文库
业界最专业的IT文库,上传资料也可以赚钱
下载
分享
Share
导读
Guide
相册
Album
记录
Doing
搜索
本版
文章
帖子
ToB圈子
用户
免费入驻
产品入驻
解决方案入驻
公司入驻
案例入驻
登录
·
注册
只需一步,快速开始
账号登录
立即注册
找回密码
用户名
Email
自动登录
找回密码
密码
登录
立即注册
首页
找靠谱产品
找解决方案
找靠谱公司
找案例
找对的人
专家智库
悬赏任务
圈子
SAAS
ToB企服应用市场:ToB评测及商务社交产业平台
»
论坛
›
软件与程序人生
›
后端开发
›
Java
›
golang channel
golang channel
傲渊山岳
金牌会员
|
2023-12-23 04:13:35
|
来自手机
|
显示全部楼层
|
阅读模式
楼主
主题
934
|
帖子
934
|
积分
2802
”不要以共享内存的方式来通信,相反,要通过通信来共享内存“
golang 的一个思想,不整文的,整点武的,具体来看channel 怎么做的
有一个很关键的 golang MPG 模型再单独分析,这篇先只分析 channel
定义
// runtim/chan.go
type hchan struct {
qcount uint // 通道里的元素数量
dataqsiz uint // 通道的总大小
buf unsafe.Pointer // 通道底层循环数组的指针
elemsize uint16 // 每个元素的大小
closed uint32 // 通道是否关闭,不能重复关闭,会 panic
elemtype *_type // 通道里元素的类型
sendx uint // 通道里发送元素的下标
recvx uint // 接受元素的下标
recvq waitq // 准备接受的协程链表
sendq waitq // 准备发送的写成链表
lock mutex // 通道锁,chan 是并发安全的
}
复制代码
链表,保存发送或接受协程
// runtim/chan.go
type waitq struct {
first *sudog
last *sudog
}
复制代码
初始化
channel使用 make 初始化
c := make(chan int) // 无缓冲
c2 := make(chan int,10) // 有缓冲
复制代码
当无缓冲时,直接创建,当有缓冲时,还要调用 mallocgc 函数,申请空间,具体代码可以看 runtime/chan.go
发送数据
使用来说很简单,下面的代码如果 channel 满了或者无缓冲无接受者的话就会阻塞
[code]c
本帖子中包含更多资源
您需要
登录
才可以下载或查看,没有账号?
立即注册
x
回复
使用道具
举报
0 个回复
倒序浏览
返回列表
快速回复
高级模式
B
Color
Image
Link
Quote
Code
Smilies
您需要登录后才可以回帖
登录
or
立即注册
本版积分规则
发表回复
回帖并转播
回帖后跳转到最后一页
发新帖
回复
傲渊山岳
金牌会员
这个人很懒什么都没写!
楼主热帖
2022你不容错过的软件测试项目实战(we ...
Swift之Codable自定义解析将任意数据类 ...
SQL Server创建表
ThinkPHP5 远程命令执行漏洞
MySQL max() min() 函数取值错误
K8S 性能优化 - K8S APIServer 调优 ...
kubernetes top查看内存CPU使用情况 ...
变量的定义和使用
Java EnumMap put()方法具有什么功能呢 ...
2022年春节后这波疫情对于国内SAP咨询 ...
标签云
存储
服务器
快速回复
返回顶部
返回列表