Hello World程序實例
Go變量實例
Go常量實例
Go for循環語句實例
Go if/else語句實例
Go switch語句實例
Go切片實例
Go範圍實例
Go函數實例
Go函數多個返回值實例
Go可變參數的函數實例
Go閉包(匿名函數)實例
Go函數遞歸實例
Go指針實例
Go指針實例
Go接口實例
Go錯誤實例
Go程序實例
Go通道實例
Go通道緩衝實例
Go通道同步實例
Go通道路線實例
Go Select實例
Go超時(timeouts)實例
Go非阻塞通道操作實例
Go關閉通道實例
Go通道範圍實例
Go計時器實例
Go斷續器實例
Go工作池實例
Go速率限制實例
Go原子計數器實例
Go互斥體實例
Go有狀態的goroutines實例
Go排序實例
Go按自定義函數排序實例
Go panic錯誤處理實例
Go延遲(defer)實例
Go集合函數實例
Go字符串函數實例
Go字符串格式化實例
Go正則表達式實例
Go JSON實例
Go時間日期實例
Go時代(Epoch)實例
Go時間格式化/解析實例
Go隨機數實例
Go數字解析實例
Go URL解析實例
Go SHA1哈希實例
Go Base64編碼實例
Go讀取文件實例
Go寫文件實例
Go行過濾器實例
Go命令行參數實例
Go命令行標誌實例
Go環境變量實例
Go執行過程實例
Go信號實例
Go退出程序實例
Go語言遞歸
遞歸是以自相似的方式重複項的過程。這同樣適用於其它編程語言,在編程語言中允許在函數內調用同一個函數稱爲遞歸調用,如下所示。
func recursion() {
recursion() /* function calls itself */
}
func main() {
recursion()
}
Go編程語言支持遞歸,即函數調用自身的函數。 但是在使用遞歸時,程序員需要注意在函數中定義或設置一個退出條件,否則它會進入無限循環。
遞歸函數非常有用,可用於解決許多數學問題,如計算數字的階乘,生成斐波那契數列等。
數字階乘示例
下面是一個例子,它使用遞歸函數來計算給定數字的階乘:
package main
import "fmt"
func factorial(i int)int {
if(i <= 1) {
return 1
}
return i * factorial(i - 1)
}
func main() {
var i int = 15
fmt.Printf("Factorial of %d is %d", i, factorial(i))
}
當上述代碼編譯和執行時,它產生以下結果:
Factorial of 15 is 2004310016
斐波那契系列示例
下面是另一個例子,它使用遞歸函數按給定數字生成斐波那契數列:
package main
import "fmt"
func fibonaci(i int) (ret int) {
if i == 0 {
return 0
}
if i == 1 {
return 1
}
return fibonaci(i-1) + fibonaci(i-2)
}
func main() {
var i int
for i = 0; i < 10; i++ {
fmt.Printf("%d ", fibonaci(i))
}
}
當上述代碼編譯和執行時,它產生以下結果:
0 1 1 2 3 5 8 13 21 34