码迷,mamicode.com
首页 > 其他好文 > 详细

Go WaitGroup的使用

时间:2018-06-18 20:22:42      阅读:134      评论:0      收藏:0      [点我收藏+]

标签:实现   AC   其他   task   output   example   lock   就是   XA   

开发过程中,经常task之间的同步问题。例如,多个子task并发完成一部分任务,主task等待他们最后结束。

在Go语言,实现同步的一种方式就是WaitGroup。

Example

package main 

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



func main() {

    var wg sync.WaitGroup


    wg.Add(3)
    go func(n int){
        fmt.Println("n:", n)
        t := time.Duration(n)*time.Second
        time.Sleep(t)

        wg.Done()
    }(1)


    go func(n int){
        fmt.Println("n:", n)
        t := time.Duration(n)*time.Second
        time.Sleep(t)
        time.Sleep(t)

        wg.Done()
    }(2)

    go func(n int){
        fmt.Println("n:", n)
        t := time.Duration(n)*time.Second
        time.Sleep(t)

        wg.Done()
    }(3)

    wg.Wait()

    fmt.Println("main exit...")
}

output:

n: 3

n: 1

n: 2

main exit...

注意

WaitGroup变量定义后,是不允许被拷贝的,即不允许作为函数参数或者赋值给其他变量。

Go WaitGroup的使用

标签:实现   AC   其他   task   output   example   lock   就是   XA   

原文地址:https://www.cnblogs.com/lanyangsh/p/9195944.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!