go语言采用晚绑定的原因及其解决方法
在go语言中,当我们使用空数组存储类型为 void -> int 的函数时,我们会遇到函数闭包的问题,即数组中函数返回的是相同的值,而不是变量在循环中的值。
这种问题是由于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() intfor 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语言中为什么函数闭包会返回相同的值?如何解决?的详细内容,更多请关注范的资源库其它相关文章!
转载请注明:范的资源库 » Go语言中为什么函数闭包会返回相同的值?如何解决?