文章目录

  • 无需声明原型。
  • 支持不定 变参。
  • 支持多返回值。
  • 支持命名返回参数。
  • 支持匿名函数和闭包。
  • 函数也是一种类型,一个函数可以赋值给变量。
  • 不支持 嵌套 (nested) 一个包不能有两个名字一样的函数。
  • 不支持 重载 (overload)
  • 不支持 默认参数 (default parameter)。
函数式编程
  • 参数,变量,返回值都可以是函数
  • 高阶函数
  • 函数>>闭包
  • 只有常量和函数,不可以有状态(选择语句,变量,循环语句都没有)。
  • 函数只可以有一个参数
package main

import "fmt"

func adder() func(int) int {
	sum := 0
	return func(v int) int {
		sum += v
		return sum
	}
}
func main() {
	a := adder()
	for i := 0; i < 10; i++ {
		fmt.Printf("0+...+%d=%d\n", i, a(i))
	}
}
------------------------------------------------------
//无状态
package main

import "fmt"

type iAdder func(int) (int, iAdder)

func adder2(base int) iAdder {
	return func(v int) (int, iAdder) {
		return base + v, adder2(base + v)
	}
}
func main() {
	a := adder2(0)
	for i := 0; i < 10; i++ {
		var s int
		s, a = a(i)
		fmt.Printf("0+...+%d=%d\n", i, s)
	}
}

/*
0+...+0=0
0+...+1=1 
0+...+2=3 
0+...+3=6 
0+...+4=10
0+...+5=15
0+...+6=21
0+...+7=28
0+...+8=36
0+...+9=45
*/
go语言函数编程闭包的应用-斐波那契数列
package main

import "fmt"

func fibonaqi() func() int {
	a, b := 0, 1
	return func() int {
		a, b = b, a+b
		return a
	}
}

func main() {
	i := fibonaqi()
	fmt.Println(i())
	fmt.Println(i())
	fmt.Println(i())
	fmt.Println(i())
	fmt.Println(i())
}
/*
1
1
2
3
5
*/
package main

import (
	"bufio"
	"fmt"
	"io"
	"strings"
)

func fibonaqi() intGen {
	a, b := 0, 1
	return func() int {
		a, b = b, a+b
		return a
	}
}

type intGen func() int

func (g intGen) Read(p []byte) (n int, err error) {
	next := g()
	if next > 10000 { //设置最大结果限制为10000
		return 0, io.EOF
	}
	s := fmt.Sprintf("%d\n", next)
	return strings.NewReader(s).Read(p)
}

func printfilecontnets(reader io.Reader) {
	scanner := bufio.NewScanner(reader)
	for scanner.Scan() {
		fmt.Println(scanner.Text())
	}
}
func main() {
	i := fibonaqi()
	printfilecontnets(i)
}
/*
1
1   
2   
3   
5   
8   
13  
21  
34  
55  
89  
144 
233 
377 
610 
987 
1597
2584
4181
6765
*/

`` `n