如何理解闭包函数的特性(golang版)

特性:闭包可以在多次调用之间保持原始状态

我们来看一个例子:

go 复制代码
func main() {
    adder := makeAdder(10)
    fmt.Println(adder(5))  // 输出:15,因为 10 + 5 = 15
    fmt.Println(adder(20)) // 输出:30,因为 10 + 20 =30
}
func makeAdder(base int) func(int) int {
    return func(num int) int {
        return base + num
    }
}

在这个例子中,我们可以将函数 func makeAdder(base int) func(int) int 拆成两部分,分别为:

  • func makeAdder(base int)
  • func(int) int

匿名函数 func(int) int 充当了 makeAdder 函数的返回值。

即 makeAdder 函数接收了一个整数作为参数,并返回一个匿名函数。而返回的匿名函数就是闭包函数,因为它引用了 makeAdder 函数作用域中的变量 base,这就是闭包函数的结构定义。

而在闭包函数特性这块,我们可以看到,在闭包函数里,我们首先令变量 base 的值为 10。

  • 第一次操作先对它加 5,得出的值为 15
  • 然后又加 20,得出来的值为 30 而不是 20

这说明每一次调用闭包的时候,它里面的值还是初始值。即闭包可以在多次调用之间保持原始状态

相关推荐
0xDevNull5 分钟前
Spring 核心教程:@Component vs @Bean 深度解析
java·后端
Michelle80236 分钟前
R语言 for循环
开发语言·r语言
小碗羊肉7 分钟前
【从零开始学Java | 第三十二篇】方法引用(Method Reference)
java·开发语言
玖釉-12 分钟前
C++ 硬核剖析:if 语句中的“双竖杠” || 到底怎么运行的?
开发语言·c++
满满和米兜13 分钟前
【Java基础】- 集合-HashSet与TreeSet
java·开发语言·算法
ltl20 分钟前
哈希表内部:开放寻址、链式、Robin Hood
后端
zhangzeyuaaa22 分钟前
Python推导式(Comprehensions)
开发语言·python
m0_7167652322 分钟前
数据结构三要素、时间复杂度计算详解
开发语言·数据结构·c++·经验分享·笔记·算法·visual studio