go语言闭包的应用
 例一:斐波那契数列

func fibonacci() func() int {
a, b := 0, 1
return func() int {
a, b = b, a+b
return a
}
}
例二:为函数实现接口

func fibonacci() func() int {
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 {
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 (node *TreeNode) Traverse() {
node.TraverseFunc(func(node *TreeNode) {
node.Print()
})
fmt.Println()
}

func (node *TreeNode) TraverseFunc(
f func(*TreeNode)) {
if node == nil {
return
}

node.Left.TraverseFunc(f)
f(node)
node.Right.TraverseFunc(f)

}
  • 总结:
  • 更为自然,不需要修饰如何访问自由变量
  • 没有Lambda表达式,但是有匿名函数