この使用例はsync.WaitGroup
正しいですか?期待どおりの結果が得られますが、wg.Add(4)
との位置についてはわかりませんwg.Done()
。で4つのゴルーチンを一度に追加することは意味がありwg.Add()
ますか?
http://play.golang.org/p/ecvYHiie0P
package main
import (
"fmt"
"sync"
"time"
)
func dosomething(millisecs time.Duration, wg *sync.WaitGroup) {
duration := millisecs * time.Millisecond
time.Sleep(duration)
fmt.Println("Function in background, duration:", duration)
wg.Done()
}
func main() {
var wg sync.WaitGroup
wg.Add(4)
go dosomething(200, &wg)
go dosomething(400, &wg)
go dosomething(150, &wg)
go dosomething(600, &wg)
wg.Wait()
fmt.Println("Done")
}
結果(期待どおり):
Function in background, duration: 150ms
Function in background, duration: 200ms
Function in background, duration: 400ms
Function in background, duration: 600ms
Done
defer wg.Done()
に、関数の最初に最初の呼び出しをすることをお勧めします。