- 闭包实现斐波那契数列
package main
import "fmt"
// 返回一个“返回int的函数”
func fibonacci() func() int {
i := -1
j := 0
return func() int {
if i == -1 {
i += 1
return 0
} else if j == 0 {
j += 1
return 1
} else {
s := i + j
i, j = j, s
return s
}
}
}
func main() {
f := fibonacci()
for i := 0; i < 10; i++ {
fmt.Println(f())
}
}