go语言采用晚绑定的原因及其解决方法
在go语言中,当我们使用空数组存储类型为 void -> int 的函数时,我们会遇到函数闭包的问题,即数组中函数返回的是相同的值,而不是变量在循环中的值。
这种问题是由于go语言采用晚绑定机制造成的。与早绑定语言不同,go语言在运行时绑定函数调用,这意味着函数对象在编译时并不确定,而是动态确定。
为了解决这个问题,可以使用两种方法:
立即学习“go语言免费学习笔记(深入)”;
使用入参
修改匿名函数的原型,添加一个额外的入参:
var fns [ls_size]func(i int) int
在匿名函数中,将循环变量作为入参传入:
fns[i] = func(i int) int { return i }
在调用数组函数时,传入循环变量:
fmt.printf("fns[%d]: %d ", n, fns[n](n))
使用闭包
另一种方法是使用闭包,即创建一个新的匿名字段,其中包含循环变量的值:
var fns [ls_size]func() int for i := 0; i < ls_size; i++ { fn := func(i int) int { return i } fns[i] = fn(i) }
在调用数组函数时,执行闭包来获取循环变量的值:
fmt.Printf("fns[%d]: %d ", n, fns[n]())
以上就是Go语言中为什么函数闭包会返回相同的值?如何解决?的详细内容,更多请关注php中文网其它相关文章!
版权声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系 yyfuon@163.com