```go
func Accumulate(value int) func() int {
return func() int {
value ++
return value
}
}
func main() {
accumulate := Accumulate(1)
fmt.Println(accumulate())
fmt.Println(accumulate())
fmt.Printf("accumulate pointer: %p\n", accumulate)
accumulate2 := Accumulate(10)
fmt.Printf("accumulate2 pointer: %p\n", accumulate2)
fmt.Println(accumulate2())
}
```
上面示例中,书籍中的输出是
```
2
3
0x4985c0
11
0x4985c0
```
书中写到
```
对比输出的日志发现accumulator 与 accumulator2 输出的函数地址不同,因此它们是两个不同的闭包实例。
```
怎么感觉是睁眼说瞎话啊,明明是一样的地址,自己在本地测试,输出结果也是相同的函数地址。
想问下有经验的朋友,是我错了,还是书里写的不对?
大概可以这么理解:函数本身也是变量的一种,只不过本身存储了一些额外的信息(函数体);因此返回一个函数和返回一个变量是一致的,所以输出的函数地址是相同的(可以将函数视为引用类型的变量)
两个不同的闭包实例是因为生成闭包的上下文不同,即传入的value和函数体是分别存储的
闭包函数Accumulate可以视为
```go
type Accumulate struct {
value int
f func() int
}
```
(实际不一定是这样),accumulate和accumulate2就是两个结构体实例,其f的值均指向同一块内存
个人理解,如有不对的地方,谢谢指正
#1