Go 匿名函数中的闭包行为:为什么 i 变量始终是 4?

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?的详细内容,更多请关注其它相关文章!