go语言的斐波那契数列fibonacci

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)
	// 初始化需要记忆住的变量left和right,这部分只会被调用一次
	left := s1
	right := s2
	return func() int {
		// 这部分开始会被调用多次,只要外部调用方调用一次f函数,这里就会被执行一次
		next := add(left, right)
		// 更新需要记忆住的变量left和right
		left = right
		right = next
		// 返回每一次f被调用的结果
		return next
	}
}

func main() {
	// 调用一次闭包函数来得到f函数,又可称为闭包函数的初始化
	f := fibonacci(0, 1)
	for i := 0; i < 10; i++ {
		// 反复不断的调用f得到结果
		fmt.Println("next value: ", f())
	}
}

这里是利用go的闭包。

Go 函数可以是闭包的。闭包是一个函数值,它来自函数体的外部的变量引用。 函数可以对这个引用值进行访问和赋值;换句话说这个函数被“绑定”在这个变量上。

例如,函数 fibonacci返回一个闭包。每个闭包都被绑定到其各自的fn_2 变量上。

闭包的概念:是可以包含自由(未绑定到特定对象)变量的代码块,这些变量不在这个代码块内或者任何全局上下文中定义,而是在定义代码块的环境中定义。要执行的代码块(由于自由变量包含在代码块中,所以这些自由变量以及它们引用的对象没有被释放)为自由变量提供绑定的计算环境(作用域)。

包的价值 : 闭包的价值在于可以作为函数对象或者匿名函数,对于类型系统而言,这意味着不仅要表示数据还要表示代码。支持闭包的多数语言都将函数作为第一级对象,就是说这些函数可以存储到变量中作为参数传递给其他函数,最重要的是能够被函数动态创建和返回。

Go语言中的闭包同样也会引用到函数外的变量。闭包的实现确保只要闭包还被使用,那么被闭包引用的变量会一直存在。

具体的闭包概念什么的,可以去百度下。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值