golang协程工作池处理多任务示例

  1. 工作方法实现
Go 复制代码
// 工作线程
// id : 线程号
// jobs : 任务通道 (chan)
// results: 完成结果通道 (chan)
func worker(id int, jobs <-chan int, results chan<- int) {
	//遍历任务
	for j := range jobs {
		fmt.Println("工作协程: ", id, "启动任务: ", j)
		fmt.Println(">>>>>>休眠2秒,模拟工作处理数据中...")
		time.Sleep(time.Second)
		fmt.Println("工作协程: ", id, "结束任务", j)
		results <- j * 2 //任务完成后写入结果到通道
	}
}

2.创建任务通道与任务执行结果通道

Go 复制代码
const numJobs = 5                  //通道容量
	jobarr := make(chan int, numJobs)  //任务通道
	results := make(chan int, numJobs) //任务执行结果通道

3.创建协程工作池

Go 复制代码
//启动3个工作协程
	for w := 1; w <= 3; w++ {
		go worker(w, jobarr, results)
	}

4.向工作通道发送任务

Go 复制代码
//向任务通道发送5个任务
	for j := 1; j <= numJobs; j++ {
		jobarr <- j //发送任务到任务通道
	}
	close(jobarr) //关闭任务通道

5.遍历执行结果:

Go 复制代码
//遍历执行结果
	for a := 1; a <= numJobs; a++ {
		<-results //读取通道数据不做处理
	}

6.完整示例

Go 复制代码
// 工作线程
// id : 线程号
// jobs : 任务通道 (chan)
// results: 完成结果通道 (chan)
func worker(id int, jobs <-chan int, results chan<- int) {
	//遍历任务
	for j := range jobs {
		fmt.Println("工作协程: ", id, "启动任务: ", j)
		fmt.Println(">>>>>>休眠2秒,模拟工作处理数据中...")
		time.Sleep(time.Second)
		fmt.Println("工作协程: ", id, "结束任务", j)
		results <- j * 2 //任务完成后写入结果到通道
	}
}


const numJobs = 5                  //通道容量
	jobarr := make(chan int, numJobs)  //任务通道
	results := make(chan int, numJobs) //任务执行结果通道
	//启动3个工程协程
	for w := 1; w <= 3; w++ {
		go worker(w, jobarr, results)
	}
	//向任务通道发送5个任务
	for j := 1; j <= numJobs; j++ {
		jobarr <- j //发送任务到任务通道
	}
	close(jobarr) //关闭任务通道
	//遍历执行结果
	for a := 1; a <= numJobs; a++ {
		<-results //读取通道数据不做处理
	}

输出结果:

Go 复制代码
工作协程:  3 启动任务:  1
>>>>>>休眠2秒,模拟工作处理数据中...
工作协程:  2 启动任务:  2
>>>>>>休眠2秒,模拟工作处理数据中...
工作协程:  1 启动任务:  3
>>>>>>休眠2秒,模拟工作处理数据中...
工作协程:  2 结束任务 2
工作协程:  2 启动任务:  4
>>>>>>休眠2秒,模拟工作处理数据中...
工作协程:  3 结束任务 1
工作协程:  3 启动任务:  5
>>>>>>休眠2秒,模拟工作处理数据中...
工作协程:  1 结束任务 3
工作协程:  3 结束任务 5
工作协程:  2 结束任务 4

执行流程示例图:

相关推荐
bug和崩溃我都要1 天前
Qt 封装 libmpv 全功能视频播放器开发指南
开发语言·qt·音视频
郝学胜-神的一滴1 天前
Qt 高级开发 018:复刻经典登录界面布局与窗口美化全解析
开发语言·c++·qt·程序人生·用户界面
郝亚军1 天前
IEEE 754 单精度浮点的SEM表示
开发语言·c++·算法
zhangjw341 天前
第15篇:Java多线程零基础入门,进程线程、线程创建方式、线程生命周期、线程安全彻底吃透
java·开发语言·面试
蝈理塘(/_\)大怨种1 天前
类和对象 (上)
java·开发语言
小新1101 天前
qt creator 将qInfo的输出日志写入日志文档,方便查看
开发语言·qt
hssfscv1 天前
QT的学习记录1
开发语言·qt·学习
SunnyDays10111 天前
Python操作Excel批注:从基础添加到高级自定义的完整指南
开发语言·python·excel
Yyyyyy~1 天前
【C++】数组篇
开发语言·c++
牛肉在哪里1 天前
ros2 从零开始27 编写广播C++
开发语言·c++·机器人