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

Go并发编程的学习代码示例:生产者消费者模型

文章目录

  • 前言
  • 代码仓库
  • 核心概念
  • main.go(有详细注释)
  • 结果
  • 总结
  • 参考资料
  • 作者的话

前言

Go并发编程学习的简单代码示例:生产者消费者模型。


代码仓库

  • yezhening/Programming-examples: 编程实例 (github.com)
  • Programming-examples: 编程实例 (gitee.com)

核心概念

并行和并发:

  • 并行:同时运行多个任务。依赖硬件中央处理器(CPU)的数量或CPU的核心数量,CPU或CPU核心的数量越多,能够同时运行的程序/进程越多
  • 并发:宏观上是“同时运行”,微观/实际上是在极短的时间内顺序运行多个程序/进程

进程、线程、协程和Go协程(goroutine):

  • 进程:资源分配的基本单位
  • 线程:内核态线程; CPU调度的基本单位
  • 协程:用户态线程;轻量级线程
  • 一个进程可以有多个线程
  • 线程和协程对应关系可以是一对一、一对多和多对多
  • goroutine:Go的协程概念,使用G(Goroutine)-P(Processor)-M(Machine)模型

Go的并发编程:

  • 使用go关键字开启多协程goroutine,而不是多进程和多线程,实现并发

  • 使用管道channal,而不是锁,实现同步互斥和数据通信

可联想进程间通信(IPC)中的管道pipe()、共享内存等方式

  • 使用select{}语句,实现监听输入/输出(I/O)操作

可联想网络编程中的监听文件描述符select()函数

相比于C、C++和其他语言,使用Go实现并发编程的逻辑很简单


main.go(有详细注释)

package main // 一个工程只有一个main包// 导入路径
import "fmt" // 用于输出// 生产者
// 参数:数据管道,单向只写;标志管道,单向只读
func producer(data_channel chan<- int, flag_channel <-chan bool) {// 循环处理,接收到消费者标志后才退出循环和函数data := 0 //生产者生产的数据for {// select{}语句监听输入/输出(I/O)操作select {case data_channel <- data: //有数据写data++case flag := <-flag_channel: //有标志读fmt.Println("生产者读标志:", flag, "结束生产")return}}
}// 消费者
// 参数:数据管道,单向只读;标志管道,单向只写
func consumer(data_channel <-chan int, flag_channel chan<- bool) {// 约定循环5次后,消费者停止消费,向生产者发送停止生产标志for i := 0; i < 5; i++ {data := <-data_channel //读数据fmt.Println("消费者读数据:", data)}flag_channel <- true //写标志return
}// 一个工程只有一个main()函数,是程序的唯一入口
func main() {data_channel := make(chan int, 0)// 数据管道,生产者向消费者传输数据// 传输int类型数据,0:无缓冲,双向flag_channel := make(chan bool, 0)// 标志管道,消费者向生产者传输标志,消费者不再消费,让生产者停止生产// 传输bool类型数据,0:无缓冲,双向go consumer(data_channel, flag_channel) //go关键字开启goroutine处理消费者任务producer(data_channel, flag_channel) // main()中是主goroutine,处理生产者任务
}

结果

PS C:\Users\DSHH\Desktop\go_test> go run main.go
消费者读数据: 0
消费者读数据: 1
消费者读数据: 2
消费者读数据: 3
消费者读数据: 4
生产者读标志: true 结束生产
PS C:\Users\DSHH\Desktop\go_test> 

总结

Go并发编程的学习代码示例:生产者消费者模型。


参考资料

  • 20个小时快速入门go语言(中)_哔哩哔哩_bilibili
  • 一文看懂Go语言协程的设计与原理 - 掘金 (juejin.cn)

作者的话

  • 感谢参考资料的作者/博主
  • 作者:夜悊
  • 版权所有,转载请注明出处,谢谢~
  • 如果文章对你有帮助,请点个赞或加个粉丝吧,你的支持就是作者的动力~
  • 文章在描述时有疑惑的地方,请留言,定会一一耐心讨论、解答
  • 文章在认识上有错误的地方, 敬请批评指正
  • 望读者们都能有所收获

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

相关文章:

  • 求a的n次幂
  • word脚标【格式:第X页(共X页)】
  • Linux --- 软件安装、项目部署
  • MATLAB应用笔记
  • ERTEC200P-2 PROFINET设备完全开发手册(6-2)
  • 算法套路八——二叉树深度优先遍历(前、中、后序遍历)
  • 视频批量剪辑:如何给视频添加上下黑边并压缩视频容量。
  • 那些你需要知道的互联网广告投放知识
  • 【hello Linux】进程程序替换
  • 【网络应用开发】实验4——会话管理
  • Linux服务器怎么分区
  • 传统机器学习(四)聚类算法DBSCAN
  • “华为杯”研究生数学建模竞赛2020年-【华为杯】A题:ASIC 芯片上的载波恢复 DSP 算法设计与实现(附获奖论文及matlab代码实现)
  • 1043.分隔数组以得到最大和
  • 微服务治理框架(Istio)的认证服务与访问控制
  • 数据结构 | 排序 - 总结
  • crontab -e 系统定时任务
  • 前后端交互系列之Axios详解(包括拦截器)
  • 定时任务之时间轮算法
  • 实验4 Matplotlib数据可视化
  • 【软件工程】为什么要选择软件工程专业?
  • 5类“计算机”专业很吃香,人才缺口巨大,就业前景良好
  • 数仓选型对比
  • 二叉树的遍历(前序、中序、后序)Java详解与代码实现
  • 如何找出消耗CPU最多的线程?
  • 【论文笔记】Attention Augmented Convolutional Networks(ICCV 2019 入选文章)
  • 虚幻图文笔记:Character Creator 4角色通过AutoSetup For Unreal Engine插件导入UE5.1的过程笔记
  • JAVAWeb04-DOM
  • C++内存管理基础知识
  • 命令执行漏洞概述