多协程写同一个slice的最佳实践

目录

问题描述

main.go

func main() {
	fmt.Println("in waitgroup test")
	result := make([]int, 0)
	var wg sync.WaitGroup
	for i := 0; i < 1000; i++ {
		wg.Add(1)
		go func() {
			defer wg.Done()
			for j := 0; j < 100000; j++ {
				result = append(result, j)
			}
		}()
	}
	wg.Wait()
	fmt.Println(len(result))
}

测试命令为go run -race main.go,会发生数据竞争。其中在append的时候会发生两种竞争,一个是slice的容量增加时会发生问题,另一个是单纯读写时也会发生问题。 这使得最终的长度总是小于预期。

0%