Golang 程序中使用 sync.WaitGroup 同步多个 Goroutine

栏目: Go · 发布时间: 6年前

内容简介:编写并发的程序时,经常会遇到需要同步多个协程/线程的状态/数据的问题。在 Golang 程序中同步多个 Goroutine 的最简单的办法就是使用 sync.WaitGroup。下面是官网的介绍:从中我们可以提取出几点关键信息:

编写并发的程序时,经常会遇到需要同步多个协程/线程的状态/数据的问题。在 Golang 程序中同步多个 Goroutine 的最简单的办法就是使用 sync.WaitGroup。

下面是官网的介绍:

A WaitGroup waits for a collection of goroutines to finish. The main goroutine calls Add to set the number of goroutines to wait for. Then each of the goroutines runs and calls Done when finished. At the same time, Wait can be used to block until all goroutines have finished.

从中我们可以提取出几点关键信息:

  1. WaitGroup 可以用于等待一系列的 Goroutine 完成任务;
  2. Add 方法须在 main goroutine 中调用;
  3. Done 方法须在其它新建的 goroutine 中调用;
  4. Wait 方法可以阻塞等待直至其它 goroutine 完成;
Talk is cheap. Show me the code.
package main

import (
    "fmt"
    "sync"
    "time"
)

func TaskA(wg *sync.WaitGroup) {
    defer wg.Done()
    time.Sleep(1 * time.Second)
    fmt.Println("task a done...")
}

func TaskB(wg *sync.WaitGroup) {
    defer wg.Done()
    time.Sleep(3 * time.Second)
    fmt.Println("task b done...")
}

func TaskC(wg *sync.WaitGroup) {
    defer wg.Done()
    time.Sleep(5 * time.Second)
    fmt.Println("task c done...")
}

func main() {
    var wg sync.WaitGroup

    //开启一个 goroutine 前,在 main goroutine 中调用 wg.Add
    //为什么强调一定要在 main goroutine 中调用 wg.Add,而不能在
    //新建的 goroutine 中调用呢?我的理解是如果延迟到新建的
    //goroutine 中调用 wg.Add 就有可能造成 wg.Wait 先执行。若是
    //如此,必定不能达到如期的效果。
    wg.Add(1)
    //传递给 goroutine 的 WaitGroup 变量必须为指针类型,因为在
    //Golang 中所有的函数参数都是值传递,也就是在函数体内会复制一
    //份参数的副本。如果不使用指针类型就无法引用到同一个 WaitGroup
    //变量,便也不能依赖 WaitGroup 来实现同步了。
    go TaskA(&wg)

    wg.Add(1)
    go TaskC(&wg)

    wg.Add(1)
    go TaskB(&wg)

    //阻塞等待直至所有其它的 goroutine 都已执行完毕
    wg.Wait()
    fmt.Println("all the tasks done...")
}

以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,也希望大家多多支持 码农网

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

王牌创业者:风口游戏

王牌创业者:风口游戏

澈言 / 百花洲文艺出版社 / 2018-2 / 48.00

《王牌创业者:风口游戏》是一部围绕互联网创业展开的商战小说:故事的主人公莫飞是“毕业即创业”的当代年轻创业者的典型代表,他大学在校时就凭借创业项目拿到了天使融资,创业几年后,当产品估值越做越大时,他却忽然遭遇创业伙伴及投资人的联手陷害,失去了自己一手建立的公司。 此时, 莫飞的女友林姿参加了一场声势浩大的创业比赛,并一举夺魁,直进决赛。可在决赛中,突如其来的一场新闻事件让她名誉扫地。最终,为......一起来看看 《王牌创业者:风口游戏》 这本书的介绍吧!

JS 压缩/解压工具
JS 压缩/解压工具

在线压缩/解压 JS 代码

MD5 加密
MD5 加密

MD5 加密工具

HEX CMYK 转换工具
HEX CMYK 转换工具

HEX CMYK 互转工具