文章永久连接:https://tech.souyunku.com/5322
程序调用自身的编程技巧称为递归( recursion)
一般来说,递归需要有边界条件、递归前进段和递归返回段
当边界条件不满足时,递归前进;当边界条件满足时,递归返回
Go 语言支持递归调用
语法
Go 语言中递归调用的语法格式如下
func recursion() {
   recursion() /* 函数调用自身 */
}
func main() {
   recursion()
}
记住,在在使用递归时,需要设置退出条件,否则递归将陷入无限循环中
递归函数对于解决数学上的问题是非常有用的,就像计算阶乘,生成斐波那契数列等
范例: 阶乘
下面的范例通过 Go 语言的递归函数实例阶乘
/**
 * file: main.go
 * author: 搜云库技术团队(tech.souyunku.com)
 * Copyright © 2015-2065 tech.souyunku.com. All rights reserved.
 */
package main
import "fmt"
func Factorial(x int) (result int) {
  if x == 0 {
    result = 1; 
  } else {
    result = x * Factorial(x - 1);
  }
  return;
}
func main() {  
    var i int = 15
    fmt.Printf("%d 的阶乘是 %d\n", i, Factorial(i))
}
编译运行以上 Go 语言范例,输出结果如下
$ go run main.go
15 的阶乘是 1307674368000
范例: 斐波那契数列
下面的范例通过 Go 语言的递归函数实现斐波那契数列
/**
 * file: main.go
 * author: 搜云库技术团队(tech.souyunku.com)
 * Copyright © 2015-2065 tech.souyunku.com. All rights reserved.
 */
package main
import "fmt"
func fibonacci(n int) int {
  if n < 2 {
   return n
  }
  return fibonacci(n-2) + fibonacci(n-1)
}
func main() {
    var i int
    for i = 0; i < 10; i++ {
       fmt.Printf("%d\t", fibonacci(i))
    }
}
编译运行以上 Go 语言范例,输出结果如下
$ go run main.go
0   1   1   2   3   5   8   13  21  34
干货推荐
附录:GOlang 教程:系列文章
- 一、Go 语言基础教程
 - 二、Go 语言 – 简介
 - 三、Go 语言环境配置
 - 四、Go 语言结构
 - 五、Go 语言基础语法
 - 六、Go 语言数据类型
 - 七、Go 语言变量
 - 八、Go 语言常量
 - 九、Go 语言运算符
 - 十、Go 语言条件语句
 - 十一、Go 语言循环语句
 - 十二、Go 语言函数
 - 十三、Go 语言 – 变量作用域
 - 十四、Go 语言 – 数组
 - 十五、Go 语言 – 字符串
 - 十六、Go 语言 – 指针
 - 十七、Go 语言 – 结构体
 - 十八、Go 语言 – 数据类型 interface
 - 十九、Go 语言 – 切片(slice)
 - 二十、Go 语言 – 哈希表(map)
 - 二十一、Go 语言 – range 关键字
 - 二十二、Go 语言 – 关键字 delete
 - 【当前读到】二十三、Go 语言递归函数
 - 二十四、Go 语言 – 类型转换
 - 二十五、Go 语言 – 错误处理
 - 二十六、Go 语言 – 开发工具
 - 二十七、Go 语言 for 循环语句
 - 二十八、Go 语言 – 多维数组
 - 二十九、Go 语言 break 语句
 - 三十、Go 语言 – 指向指针的指针
 - 三十一、Go 语言 – 指针作为函数参数
 - 三十二、Go 语言 goto 语句
 - 三十三、Go 语言 if 语句
 - 三十四、Go 语言函数值传递调用
 - 三十五、Go 语言 for 循环嵌套
 - 三十六、Go 语言 – 向函数传递数组
 - 三十七、Go 语言 – 函数 – 引用传值
 - 三十八、Go 语言 select 语句
 - 三十九、Go 语言 if…else 语句
 - 四十、Go 语言 switch 语句
 - 四十一、Go 语言 – 闭包函数
 - 四十二、Go 语言指针数组
 - 四十三、Go 语言 if 语句嵌套
 - 四十四、Go 语言 – 函数作为值
 - 四十五、Go 语言函数方法
 - 四十六、Go 语言 continue 语句