文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

高效并发编程:使用Go WaitGroup和协程池

2023-10-08 17:22

关注

在Go语言中,可以使用WaitGroup和协程池来实现高效的并发编程。
1. WaitGroup:WaitGroup是一个计数器,用于等待一组协程的完成。在主协程中添加计数器的数量,然后在每个协程中完成任务后减少计数器的数量。主协程可以使用Wait方法等待所有协程完成任务。
下面是一个使用WaitGroup的示例代码:
```go
package main
import (
"fmt"
"sync"
)
func main() {
var wg sync.WaitGroup
wg.Add(2)
go func() {
defer wg.Done()
// 第一个协程的任务
fmt.Println("协程1完成")
}()
go func() {
defer wg.Done()
// 第二个协程的任务
fmt.Println("协程2完成")
}()
wg.Wait()
fmt.Println("所有协程完成")
}
```
输出结果为:
```
协程2完成
协程1完成
所有协程完成
```
2. 协程池:协程池是一组可重用的协程,用于执行并发任务。通过限制协程的数量,可以避免创建过多的协程导致系统资源耗尽。
下面是一个简单的协程池的实现示例:
```go
package main
import (
"fmt"
)
func worker(id int, jobs <-chan int, results chan<- int) {
for j := range jobs {
// 处理任务的逻辑
fmt.Println("worker", id, "开始处理任务", j)
results <- j * 2
fmt.Println("worker", id, "完成任务", j)
}
}
func main() {
const numJobs = 5
jobs := make(chan int, numJobs)
results := make(chan int, numJobs)
// 启动3个协程池
for w := 1; w <= 3; w++ {
go worker(w, jobs, results)
}
// 添加任务到任务通道
for j := 1; j <= numJobs; j++ {
jobs <- j
}
close(jobs)
// 读取任务结果
for r := 1; r <= numJobs; r++ {
fmt.Println(<-results)
}
}
```
输出结果为:
```
worker 3 开始处理任务 1
worker 1 开始处理任务 2
worker 2 开始处理任务 3
worker 1 完成任务 2
worker 1 开始处理任务 4
worker 2 完成任务 3
worker 3 完成任务 1
worker 1 完成任务 4
worker 2 开始处理任务 5
worker 2 完成任务 5
2
4
6
8
10
```
这个示例中,我们启动了3个协程池,每个协程池会不断从任务通道中获取任务并处理。任务结果会被发送到结果通道中,最后读取结果通道中的结果。
通过使用WaitGroup和协程池,我们可以高效地实现并发编程,并充分利用多核处理器的性能。

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     807人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     351人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     314人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     433人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     221人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯