go闭包中的变量是否是共享的?

本文探讨了Go语言中闭包和共享变量的概念,通过一个累加器的例子展示了闭包如何使用共享变量。初始代码未能实现累加效果,原因在于每次调用`adder()`都创建了一个新的函数实例,它们各自拥有独立的变量空间。通过调整代码,确保使用同一函数实例,实现了共享变量的累加功能。此外,还提供了验证函数地址的方法来证明每个函数实例的独立性,并给出了正确的实现方式。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

问题

可能题目的描述不是很准确。题中的”共享变量“,主要出现在go中闭包的一种用法——将函数作为返回值。

比如可以用这种方法实现下面的累加器(代码来自于 《the way to go》)

func adder() func(int) int {
	var x int 
	return func(i int) int {
		x = i + x
		return x
	}
}

写一个主函数测试以下

package main

import "fmt"

func main() {
	fmt.Print(adder()(1), "-")
	fmt.Print(adder()(20), "-")
	fmt.Print(adder()(300), "-")
}

得到结果

1-20-300-

似乎并没有达到累加的效果,好像这里的x并不是共享的。

验证

实际上是因为我调用了三次adder()方法,得到了三个函数,三个函数各自拥有自己的空间,互不共享。

为了验证这个问题,我们可以打印一下三个函数的地址

func main() {
	var f1 = adder()
	var f2 = adder()
	var f3 = adder()

	fmt.Printf("%v\n", f1)
	fmt.Printf("%v\n", f2)
	fmt.Printf("%v\n", f3)
}

运行结果

0xafdce0
0xafdcc0
0xafdca0

可见三个函数占用了不同的空间。

解决

所以应该这么做,先获取一个共享的函数,用同一个函数做累加。

func main() {
	var f = adder()
	fmt.Print(f(1), "-")
	fmt.Print(f(20), "-")
	fmt.Print(f(300), "-")
}

运行结果

1-21-321-

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值