Go语言为什么采用晚绑定机制?
go语言采用晚绑定的缘由
如示例代码所示,在创建空数组后,需要为其元素赋值为指向函数的指针,且该函数无参数,返回一个 int 值。
在循环体中,为数组元素赋值为匿名函数,该函数返回循环变量 i 的值。循环执行完毕后,再次遍历数组,依次调用其中的函数,并将函数返回值打印输出。
在编译时,会生成一个指向函数地址的数组,该数组中的所有函数都将使用相同的 i 值。由于 i 在循环结束后才被更新,因此在调用数组中函数时,所有函数都会返回 i 的最终值 5。
为了解决这个问题,go 采用了晚绑定机制。晚绑定允许函数在运行时决定要使用的值,避免了在编译时锁定值的情况。
除了使用闭包来传递循环变量,go 还提供了其他解决办法,例如在匿名函数中引入一个额外的参数,使函数能够访问循环变量。
修改后的代码如下:
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]: 0 fns[1]: 1 fns[2]: 2 fns[3]: 3 fns[4]: 4
以上就是Go语言为什么采用晚绑定机制?的详细内容,更多请关注硕下网其它相关文章!