golang sync.WaitGroup使用示例

siskinc · · 720 次点击 · · 开始浏览    
这是一个创建于 的文章,其中的信息可能已经有所发展或是发生改变。

golang中同步方式

golang中有2种方式同步程序

  1. 一种使用channel
  2. 另一种使用锁机制。

sync.WaitGroup方法

sync.WaitGroup只有3个方法:

  1. Add()
  2. Done()
  3. Wait()

其中Done()是Add(-1)的别名。
简单的来说,使用Add()添加计数,Done()减掉一个计数,计数不为0, 阻塞Wait()的运行。

要注意的有一点。sync文档已经说明了的,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.也就是说,在运行main函数的goroutine里运行Add()函数,在其他的goroutine里面运行Done()函数。这个我是踩过雷了的。
最简单的案例就是sync文档里面的example,这里简单写了一个例子。

package main

import (
    "fmt"
    "time"
    "sync"
)
var wg sync.WaitGroup
func main() {

    for i := 0; i < 100; i++ {
        wg.Add(1)
        go fun(i)
    }
    fmt.Println("exit")
    wg.Wait()
}

func fun(i int)  {
    time.Sleep(time.Second * 2)
    fmt.Println(i)
    wg.Done()
}

有疑问加站长微信联系(非本文作者)

本文来自:简书

感谢作者:siskinc

查看原文:golang sync.WaitGroup使用示例

入群交流(和以上内容无关):加入Go大咖交流群,或添加微信:liuxiaoyan-s 备注:入群;或加QQ群:692541889

720 次点击  
加入收藏 微博
暂无回复
添加一条新回复 (您需要 登录 后才能回复 没有账号 ?)
  • 请尽量让自己的回复能够对别人有帮助
  • 支持 Markdown 格式, **粗体**、~~删除线~~、`单行代码`
  • 支持 @ 本站用户;支持表情(输入 : 提示),见 Emoji cheat sheet
  • 图片支持拖拽、截图粘贴等方式上传