package main
import (
"bufio"
"fmt"
"io"
"strings"
)
/*
golang函数式编程->主要体现在闭包上面
函数式编程vs函数指针{
1.函数是一等公民:参数,变量,返回值都可以是函数
2.高阶函数
3.函数->闭包
4."正统"函数式编程{ //golang语言是通用性语言,不会在此方面做过多文章
1.不可变性:不能有状态,只有常量和函数
2.函数只能有一个参数
}
}
闭包:函数体{
局部变量,
自由变量
}
go语言闭包的应用:更为自然,不需要修饰如何访问自由变量
go语言没有lambda表达式,但是有匿名函数
*/
// 斐波那契数列生成器 1, 1, 2, 3, 5, 8, 13, 21 ...
func fibonacci() intGen {
a, b := 0, 1
return func() int {
// 相当于 a向后移动一个位置(a = b) b等于前两个值的和
a, b = b, a+b
return a
}
}
func adder() func(int) int {
sum := 0 // 自由变量
return func(v int) int { // 返回的是闭包
sum += v // v是局部变量
return sum
}
}
type intGen func() int
func (g intGen) Read(p []byte) (n int, err error) {
next := g()
if next > 10000 {
return 0, io.EOF
}
s := fmt.Sprintf("%d\n", next)
// TODO: incorrect if p is too small!!
return strings.NewReader(s).Read(p)
}
func printFileContents(reader io.Reader) {
scanner := bufio.NewScanner(reader)
for scanner.Scan() {
fmt.Println(scanner.Text())
}
}
func main() {
a := adder()
for i := 0; i < 10; i++ {
fmt.Printf("0 + 1 + ... + %d = %d\n", i, a(i))
}
fmt.Println("斐波那契数列")
f := fibonacci()
// for i := 0; i < 10; i++ {
// fmt.Println(f())
// }
printFileContents(f)
}