go语言采坑:闭包共享变量问题
话不多说,直接看代码和注释:
package main
import (
"fmt"
"time"
)
func main() {
// 错误示例(打印出的结果是5个6)
fmt.Println("closure buggy example...")
for i := 1; i <= 5; i++ {
// 每个goroutine共享一个变量,goroutine还没开始的时候,i已经变成了6
go func() {
fmt.Println(i)
}()
}
time.Sleep(1 * time.Second)
// 正确示例1:
fmt.Println("normal example...")
for i := 1; i <= 5; i++ {
go func(i int) { // 使用局部变量
fmt.Println(i)
}(i)
}
time.Sleep(1 * time.Second)
// 正确示例2:
fmt.Println("normal example 2...")
for i := 1; i <= 5; i++ {
i := i // 为每个闭包创建一个变量
go func() {
fmt.Println(i)
}()
}
time.Sleep(1 * time.Second)
}
运行得到的结果如下:
closure buggy example...
6
6
6
6
6
normal example...
5
2
1
3
4
normal example 2...
5
2
1
3
4
原因和解决方法见代码注释。第一个例子是错误示例,第二、三个例子是正确示例。
本作品采用《CC 协议》,转载必须注明作者和本文链接