go语言来解释闭包的概念

go语言来解释闭包的概念

 

版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/leon_wzm/article/details/79818992

说不清楚的闭包

闭包的概念大家都听说过,但是往往解释的越多,越说不明白。今天我用GoLang的课后斐波那契数列的练习题来秒说明一下闭包的套路。记住:一切都是套路!

斐波那契数列

斐波那契数列是一种数列,它的规律是数列中某一个位置的数字是该位置的前两个位置的数字之和。 
比如,指定两个起始数字,比如0和1,那么斐波那契数列就会像这样:0, 1, 1, 2, 3, 5, 8, 13。。。

先上代码

package main

import "fmt"

// 单纯的两个数字相加的函数
func add(x, y int) int {
    return x + y
}

// fibonacci 函数会返回一个返回 int 的函数。
func fibonacci(s1, s2 int) func() int {
    fmt.Println("fibonacci start with ", s1, " and ", s2)
    // 套路3: 初始化需要记忆住的变量left和right,这部分只会被调用一次
    left := s1
    right := s2
    return func() int {
        // 这部分开始会被调用多次,只要外部调用方调用一次f函数,这里就会被执行一次
        next := add(left, right)
        // 套路4: 更新需要记忆住的变量left和right
        left = right
        right = next
        // 套路5: 返回每一次f被调用的结果
        return next
    }
}

func main() {
    // 套路1: 调用一次闭包函数来得到f函数,又可称为闭包函数的初始化
    f := fibonacci(0, 1)
    for i := 0; i < 10; i++ {
        // 套路2: 反复不断的调用f得到结果
        fmt.Println("next value: ", f())
    }
}
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23
  • 24
  • 25
  • 26
  • 27
  • 28
  • 29
  • 30
  • 31
  • 32
  • 33
  • 34
  • 35

把代码拷贝到fibonacci.go文件中,然后运行go run fibonacci.go看结果吧。 
以下是运行结果: 
fibonacci start with 0 and 1 
next value: 1 
next value: 2 
next value: 3 
next value: 5 
next value: 8 
next value: 13 
next value: 21 
next value: 34 
next value: 55 
next value: 89

闭包的调用理念

1,会被外界调用一次来初始化 
2,返回一个函数f给调用方 
3,调用方接下去只要重复调用f就可以达到目的

闭包的编程套路

1, 在闭包函数中且在返回函数的体外,定义每下一次计算需要记忆的变量,如left和right 
2,在返回函数的体中去实现对于记忆变量的每次更新 
3,在返回函数的体中返回调用方希望得到的结果

总结

整个流程和机器学习里面的神经网络的RNN算法非常类似,如果有RNN背景的同学会非常快的理解。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
闭包函数是指内部函数可以访问外部函数的局部变量,并且在外部函数执行结束后,依然可以访问和修改这些变量。在Go语言中,函数也可以作为返回值返回,形成闭包闭包函数可以用来实现函数式编程的一些特性。 函数式编程是一种编程范式,它将计算过程看作是一系列函数的应用。在函数式编程中,函数被视为一等公民,可以像其他数据类型一样传递、赋值和返回。函数式编程强调使用纯函数,即不依赖于外部状态和副作用的函数,这样可以提高代码的可读性、可维护性和并发性。 在Go语言中,闭包函数和函数式编程可以结合使用。通过闭包函数,我们可以在函数内部定义其他函数,并且这些内部函数可以访问外部函数的局部变量。这样就可以实现一些函数式编程的特性,例如高阶函数、柯里化和函数组合等。 以下是一个示例代码,演示了Go语言闭包函数和函数式编程的用法: ```go package main import "fmt" // 返回一个闭包函数,用于累加计数 func counter() func() int { count := 0 return func() int { count++ return count } } // 使用高阶函数将一个整数加倍 func double(n int) int { return n * 2 } // 使用高阶函数将两个整数相加 func add(a, b int) int { return a + b } func main() { // 使用闭包函数创建一个计数器 c := counter() // 调用计数器函数,并打印结果 fmt.Println(c()) // 输出: 1 fmt.Println(c()) // 输出: 2 // 使用高阶函数将整数加倍,并打印结果 fmt.Println(double(5)) // 输出: 10 // 使用高阶函数将两个整数相加,并打印结果 fmt.Println(add(3, 4)) // 输出: 7 } ``` 在上面的示例中,`counter`函数返回了一个闭包函数,用于实现简单的计数器。`double`函数和`add`函数都是高阶函数,可以作为参数传递给其他函数使用。这些示例展示了Go语言闭包函数和函数式编程的一些用法。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值