网站首页 > 技术文章 正文
创建两个并发的goroutine,每个goroutine都会执行一些任务并输出结果:
package main
import (
"fmt"
"sync"
)
func main() {
// 创建一个等待组,用于等待所有的goroutine完成
var wg sync.WaitGroup
// 设置等待组的计数器为2,表示有两个goroutine要等待
wg.Add(2)
// 启动第一个goroutine
go func() {
defer wg.Done() // 在goroutine执行完毕后通知等待组计数器减1
// 执行一些任务
for i := 1; i <= 5; i++ {
fmt.Println("Goroutine 1:", i)
}
}()
// 启动第二个goroutine
go func() {
defer wg.Done() // 在goroutine执行完毕后通知等待组计数器减1
// 执行一些任务
for i := 1; i <= 5; i++ {
fmt.Println("Goroutine 2:", i)
}
}()
// 等待所有的goroutine完成
wg.Wait()
fmt.Println("All goroutines completed.")
}
在上述示例中,我们使用sync.WaitGroup来等待所有的goroutine完成。在main函数中,首先创建了一个WaitGroup对象wg,并调用wg.Add(2)来设置等待组的计数器为2,表示有两个goroutine要等待。
然后,我们启动了两个goroutine,每个goroutine都执行一些任务,并在任务完成后通过defer wg.Done()通知等待组计数器减1。
最后,我们调用wg.Wait()来阻塞主goroutine,直到所有的goroutine都完成。一旦所有的goroutine都执行完毕,我们输出"All goroutines completed."。
这样就实现了一个简单的并发编程示例,两个goroutine并发执行任务。你可以根据自己的需求扩展和修改这个示例。
- 上一篇: 并发编程的奇技淫巧:Go语言调度器的内在工作机制
- 下一篇: Go 语言并发编程实践:从入门到进阶
猜你喜欢
- 2024-12-01 Go 并发可视化解释 — 通道
- 2024-12-01 Go并发编程面试15题
- 2024-12-01 Go 语言并发编程实践:从入门到进阶
- 2024-12-01 并发编程的奇技淫巧:Go语言调度器的内在工作机制
- 2024-12-01 Goroutine 并发调度模型深度解析之手撸一个高性能 goroutine 池
- 2024-12-01 每天2分钟学习GO语言编程(十九)并发简明教程
- 2024-12-01 并发编程,程序员必修课,来看go语言的巧妙实现,极为干练
- 2024-12-01 Go项目中如何限制并发数?Atomic必须掌握
- 2024-12-01 Go语言并发入门
- 2024-12-01 Go 语言 Goroutines 协程并发
- 最近发表
- 标签列表
-
- cmd/c (57)
- c++中::是什么意思 (57)
- sqlset (59)
- ps可以打开pdf格式吗 (58)
- phprequire_once (61)
- localstorage.removeitem (74)
- routermode (59)
- vector线程安全吗 (70)
- & (66)
- java (73)
- org.redisson (64)
- log.warn (60)
- cannotinstantiatethetype (62)
- js数组插入 (83)
- resttemplateokhttp (59)
- gormwherein (64)
- linux删除一个文件夹 (65)
- mac安装java (72)
- reader.onload (61)
- outofmemoryerror是什么意思 (64)
- flask文件上传 (63)
- eacces (67)
- 查看mysql是否启动 (70)
- java是值传递还是引用传递 (58)
- 无效的列索引 (74)