Go并发可视化解释:sync.WaitGroup

开发
Golang倾向于保持一切尽可能简洁,因此与其他编程语言中的CountDownLatch不同,sync.WaitGroup默认情况下不支持超时。在这种情况下,选择语句可能会有所帮助。

场景

Avito是一名校车司机,他帮助4个Gopher孩子上学。每天,Avito在他们的社区等待孩子们。他不知道孩子们需要多长时间,但他确切地知道有4个孩子他需要等待。

1*aZnEggopv4Tsbyyj3e5JFg.png

当一个孩子准备好时,他/她会说:Done(),将计数器减1。Avito仍然被阻塞,因为计数器仍然大于0。他必须等到所有其他孩子准备好。

1*qouGWmMAqY2CDrzz5widhQ.png

如果有两个孩子同时准备好,它们的同时准备会导致WaitGroup出现不一致吗?绝对不会。与sync包中的大多数其他组件一样,WaitGroup具有内置的同步机制,以处理并发。因此,计数器减少了准备好的孩子数量。

1*057bX4zo_LCzEkdzGyDYpA.png

在最后一个孩子准备好后,Avito启动引擎,将他们送到学校。

1*rjH8OR3t7QgUx-dO-Iszeg.png

就是这样!正如我所说,sync.WaitGroup很简单。

超时

如果一个孩子花费太多时间准备,他们会不会因此迟到?如果Avito在时间到达时不管怎样都开始行驶会更好吗?嗯,Golang倾向于保持一切尽可能简洁,因此与其他编程语言中的CountDownLatch(例如Java中的)不同,sync.WaitGroup默认情况下不支持超时。在这种情况下,选择语句可能会有所帮助。

func main() {
    wg := sync.WaitGroup{}
    wg.Add(1)

    go func() {
        defer wg.Done()
        time.Sleep(5 * time.Second)
    }()

    done := make(chan bool)

    go func() {
        wg.Wait()
        close(done)
    }()

    select {
    case <-done:
        log.Println("All done")
    case <-time.After(1 * time.Second):
        log.Println("Hit timeout")
    }
}

孩子等待

在上面的示例中,Avito(主Goroutine)等待孩子(子Goroutines)。当我们希望子Goroutines等待主Goroutine时,WaitGroup也可以使用。想象一下孩子们正在进行体育课。Torcher - 体育老师,在学生中主持比赛。他向WaitGroup中Add(1),并要求所有孩子在相同的WaitGroup上Wait()。

1*btDQK4QKsu1HkEpfJDa2EA.png

当Torcher调用wg.Done()时,计数器变为0,允许所有孩子同时开始奔跑。

1*VkV3VlRTx5jxXhauBH0_Dg.png

展示你的代码!

package main

import (
    "log"
    "sync"
    "time"
)

func main() {
    kids := []string{"Partier", "Stringer", "Candier", "Swimmer"}
    wg := sync.WaitGroup{}
    wg.Add(len(kids))

    for _, kid := range kids {
        go func(name string) {
            defer wg.Done()
            prepare(name)
        }(kid)
    }

    log.Printf("Avito: I'm waiting for %d kids\n", len(kids))
    wg.Wait()
    log.Println("Avito: The kids are all ready, go!")
}

func prepare(name string) {
    log.Printf("%v: I'm preparing for school\n", name)
    time.Sleep(2 * time.Second)
    log.Printf("%v: I'm ready\n", name)
}
责任编辑:赵宁宁 来源: 小技术君
相关推荐

2023-09-25 12:45:45

Go 语言可视化sync.Mute

2023-10-06 23:31:25

可视化Go

2023-09-15 11:32:18

selectGo可视化解释

2024-06-05 11:06:22

Go语言工具

2023-06-05 09:23:00

Golang同步工具

2023-09-11 10:17:20

Go编程语言

2024-01-08 13:40:00

并发安全• 数量

2017-11-10 11:27:48

Go并行算法

2023-01-30 15:41:10

Channel控制并发

2024-09-06 10:48:13

2021-01-28 10:55:31

算法可视化数据

2020-07-01 09:08:55

神经网络深度学习网络

2017-12-26 14:05:21

润乾大屏可视化

2021-09-30 09:21:28

Go语言并发编程

2024-10-14 08:51:52

协程Go语言

2024-08-12 10:52:00

AI模型

2020-03-11 14:39:26

数据可视化地图可视化地理信息

2011-07-11 22:22:38

2011-07-02 14:12:00

2022-08-15 08:02:09

Go程序函数
点赞
收藏

51CTO技术栈公众号