
理解 go 中匿名函数的闭包行为
在 go 中,匿名函数拥有闭包行为,这意味着它们可以访问定义它们的函数作用域内的变量。
示例
package main
import (
"fmt"
)
func main() {
var fs = [4]func(){}
var fi = [4]int{}
for i := 0; i < 4; i++ {
fs[i] = func() { fmt.println("closure i = ", i); fi[i-1] = i }
}
for _, f := range fs {
f()
}
fmt.println(fi)
}问题:为什么匿名函数中的 i 变量是 4?
当匿名函数被调用时,它能访问定义它的函数作用域中的变量。在给定的示例中,当匿名函数被调用时,i 已经递增到 4。
解决方案:
如果你想要匿名函数访问定义它时的 i 值,则需要显式地保留该值,而不是使用引用它的变量 i。
for i := 0; i < 4; i++ {
j := i
fs[i] = func() { fmt.Println("closure i = ", j); fi[i-1] = i }
}以上就是Go 匿名函数中的闭包行为:为什么 i 变量始终是 4?的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号