当前位置: 首页 > news >正文

channel并发编程

不要通过共享内存通信,要通过通信共享内存。
channel是golang并发编程中一种重要的数据结构,用于多个goroutine之间进行通信。
我们通常可以把channel想象成一个传送带,将goroutine想象成传送带周边的人,一个传送带的上游放上物品,通过传送带的传输,下游的人可以将物品取走。
在这里插入图片描述

package mainimport ("fmt""time"
)func main() {c := make(chan string, 2)s := []string{"A", "B", "C", "D"}go func() {defer close(c)for _, v := range s {fmt.Printf("send to chan %v\n", v)c <- vtime.Sleep(1 * time.Second)}}()time.Sleep(5 * time.Second)for v := range c {fmt.Printf("recieved %v\n", v)}
}

在这里插入图片描述

package mainimport ("fmt""time"
)func main() {c := make(chan string, 2)s := []string{"A", "B", "C", "D"}go func() {//defer close(c)for _, v := range s {fmt.Printf("send to chan %v\n", v)c <- vtime.Sleep(1 * time.Second)}}()time.Sleep(5 * time.Second)for v := range c {fmt.Printf("recieved %v\n", v)}
}

在这里插入图片描述

http://www.lryc.cn/news/142467.html

相关文章:

  • 苹果新健康专利:利用 iPhone、Apple Watch 来分析佩戴者的呼吸情况
  • 数据分析基础-数据可视化02-不同数据类型的可视化概念及原则
  • QT项目使用Qss的总结
  • suricata初体验+wireshark流量分析
  • 机器学习:异常检测实战
  • 数据结构1
  • 自然语言处理学习笔记(七)————字典树效率改进
  • forEach和map有什么区别,使用场景?
  • 【Spring Boot】SpringBoot完整实现社交网站系统
  • Modbus转Profinet网关连接三菱变频器博图快速配置
  • 8.9 【C语言】有关指针的小结
  • WordPress Nginx伪静态规则设置以及二级目录规则
  • 2023年高教社杯 国赛数学建模思路 - 复盘:人力资源安排的最优化模型
  • React内置函数之startTransition与useTransition
  • 观察者模式简介
  • 统计程序两个点之间执行的指令数量
  • 时序预测 | MATLAB实现基于TSO-XGBoost金枪鱼算法优化XGBoost的时间序列预测(多指标评价)
  • java- ConcurrentHashMap 并发
  • java练习8.100m小球落地
  • Android JNI系列详解之生成指定CPU的库文件
  • Leetcode每日一题:1448. 统计二叉树中好节点的数目
  • 华为OD七日集训第2期 - 按算法分类,由易到难,循序渐进,玩转OD(文末送书)
  • 3d max插件CG MAGIC中的蜂窝材质功能可提升效率吗?
  • 一句话木马攻击复现:揭示黑客入侵的实战过程
  • 【游戏开发教程】Unity Cinemachine快速上手,详细案例讲解(虚拟相机系统 | 新发出品 | 良心教程)
  • 当图像宽高为奇数时,如何计算 I420 格式的uv分量大小
  • 结构型模式-代理模式
  • SpringBoot+Redis BitMap 实现签到与统计功能
  • P5739 【深基7.例7】计算阶乘
  • scikit-learn中OneHotEncoder用法