Go 匿名函数中的闭包行为:为什么 i 变量始终是 4?
理解 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?的详细内容,更多请关注其它相关文章!