Go 中匿名函数的返回值为什么都相同?如何使用闭包解决这个问题?

go 中匿名函数的返回值为什么都相同?如何使用闭包解决这个问题?

为什么 go 采用晚绑定

在 go 中,匿名函数可以像变量一样被存储在数组中。然而,在以下示例中,通过循环创建的匿名函数的返回值都是相同的:

package mainimport "fmt"const ls_size int = 5func main() {    // 创建空数组    var fns [ls_size]func() int    // 循环    for i := 0; i < ls_size; i++ {        fns[i] = func() int {            return i        }    }    // 遍历数组并调用函数    for n := 0; n < ls_size; n++ {        fmt.printf("fns[%d]: %d", n, fns[n]())    }}

登录后复制

输出:

fns[0]: 5fns[1]: 5fns[2]: 5fns[3]: 5fns[4]: 5

登录后复制

这是因为循环变量 i 在离开循环块后无法访问,这是许多编译型语言的常见行为。但每个匿名函数返回的值都一样,这一点又与 python、ruby 和 groovy 等语言一致。

为了解决这个问题,go 采用晚绑定。也就是说,函数在调用时才会绑定到特定的值。以下是如何使用闭包解决相同问题的另一种方法:

package mainimport "fmt"const ls_size int = 5func main() {    // 创建空数组    var fns [ls_size]func(x int) int    // 循环    for i := 0; i < ls_size; i++ {        fns[i] = func(i int) int {            return i        }    }    // 遍历数组并调用函数    for n := 0; n < ls_size; n++ {        fmt.printf("fns[%d]: %d", n, fns[n](n))    }}

登录后复制

输出:

fns[0]: 0fns[1]: 1fns[2]: 2fns[3]: 3fns[4]: 4

登录后复制

以上就是Go 中匿名函数的返回值为什么都相同?如何使用闭包解决这个问题?的详细内容,更多请关注【创想鸟】其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至253000106@qq.com举报,一经查实,本站将立刻删除。

发布者:PHP中文网,转转请注明出处:https://www.chuangxiangniao.com/p/2312677.html

(0)
上一篇 2025年2月28日 12:58:22
下一篇 2025年2月23日 17:51:53

AD推荐 黄金广告位招租... 更多推荐

相关推荐

发表回复

登录后才能评论