小伙伴们有没有觉得学习
Golang很有意思?有意思就对了!今天就给大家带来
《如何使用 Channel 或 Context 等待多个子协程执行完毕?》,以下内容将会涉及到
,若是在学习中对其中部分知识点有疑问,或许看了本文就能帮到你!,
,
协程等待:通过 channel 或 context 实现,想要等待多个子协程执行完毕,可以通过使用 channel 或 context 实现,类似于 sync.waitgroup 的功能。,
channel,channel 用于在协程间通讯。可以通过创建一个缓冲 channel,并为每个协程发送一个值,来实现子协程完成后通知主协程。,
context,context 是一种更通用的机制,可以用来传播取消信号或其他值。可以通过使用 withcancel 函数创建一个 context,并传递给子协程。当主协程取消 context 时,子协程会自动终止。,文中关于的知识介绍,希望对你的学习有所帮助!若是受益匪浅,那就动动鼠标收藏这篇《如何使用 Channel 或 Context 等待多个子协程执行完毕?》文章吧,也可关注golang学习网公众号了解相关技术文章。,协程等待:通过 channel 或 context 实现,小伙伴们有没有觉得学习
Golang很有意思?有意思就对了!今天就给大家带来
《如何使用 Channel 或 Context 等待多个子协程执行完毕?》,以下内容将会涉及到
,若是在学习中对其中部分知识点有疑问,或许看了本文就能帮到你!,
当前位置: > > > > 如何使用 Channel 或 Context 等待多个子协程执行完毕?
如何使用 Channel 或 Context 等待多个子协程执行完毕?
2024-11-17 14:09:56
0浏览
收藏
小伙伴们有没有觉得学习Golang很有意思?有意思就对了!今天就给大家带来《如何使用 Channel 或 Context 等待多个子协程执行完毕?》,以下内容将会涉及到,若是在学习中对其中部分知识点有疑问,或许看了本文就能帮到你!

协程等待:通过 channel 或 context 实现
想要等待多个子协程执行完毕,可以通过使用 channel 或 context 实现,类似于 sync.waitgroup 的功能。
channel
channel 用于在协程间通讯。可以通过创建一个缓冲 channel,并为每个协程发送一个值,来实现子协程完成后通知主协程。
import "math/rand"
import "time"
func main() {
const num = 10
ch := make(chan int, num)
for i := 0; i < num; i++ {
go func() {
fmt.println("goroutine start: ", i)
t := rand.intn(5) + 1
time.sleep(time.duration(t) * time.second)
fmt.println("goroutine end: ", i)
ch <- 0
}()
}
fmt.println("main start")
for i := 0; i < num; i++ {
<-ch
fmt.println("main get: ", i)
}
fmt.println("main end")
}
context
context 是一种更通用的机制,可以用来传播取消信号或其他值。可以通过使用 withcancel 函数创建一个 context,并传递给子协程。当主协程取消 context 时,子协程会自动终止。
import "context"
func main() {
const num = 10
ctx, cancel := context.WithCancel(context.Background())
ch := make(chan int, num)
for i := 0; i < num; i++ {
go func(ctx context.Context) {
fmt.Println("goroutine start: ", i)
select {
case <-ctx.Done():
fmt.Println("goroutine cancelled: ", i)
return
default:
}
t := rand.Intn(5) + 1
time.Sleep(time.Duration(t) * time.Second)
fmt.Println("goroutine end: ", i)
ch <- 0
}(ctx)
}
fmt.Println("main start")
for i := 0; i < num; i++ {
<-ch
fmt.Println("main get: ", i)
}
cancel()
fmt.Println("main end")
}
文中关于的知识介绍,希望对你的学习有所帮助!若是受益匪浅,那就动动鼠标收藏这篇《如何使用 Channel 或 Context 等待多个子协程执行完毕?》文章吧,也可关注golang学习网公众号了解相关技术文章。
- Go 语言引入第三方库后,如何避免库作者修改代码导致项目无法使用?
- 转换后字符串的数字总和
