函数式编程
闭包
- 闭包 = 匿名函数 + 自由变量的引用

func adder() func(value int) int {
sum := 0
return func(value int) int {
sum += value
return sum
}
}
func main() {
adder := adder()
for i := 0; i < 10; i++ {
fmt.Println(adder(i))
}
}
例子
package main
func fibonacci() func() int {
a, b := 0, 1
return func() int {
a, b = b, a+b
return a
}
}
func main() {
f := fibonacci()
println(f())
println(f())
println(f())
println(f())
println(f())
}
func fibonacci() 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()
s := fmt.Sprintf("%d\n", next)
if next > 200 {
return 0, io.EOF
}
return strings.NewReader(s).Read(p)
}
func printFileContents(reader io.Reader) {
scanner := bufio.NewScanner(reader)
for scanner.Scan() {
fmt.Println(scanner.Text())
}
}
func main() {
f := fibonacci()
printFileContents(f)
}
func (node *Node) TraverseFunc(f func(*Node)) {
if node == nil {
return
}
node.left.TraverseFunc(f)
f(node)
node.right.TraverseFunc(f)
}
nodeCount := 0
root.TraverseFunc(func(n *Node) {
nodeCount++
})
fmt.Println(nodeCount)