go闭包函数的特点

所谓闭包就是一个函数“捕获”了和它在同一作用域的其它常量和变量。这就意味着当闭包被调用的时候,不管在程序什么地方调用,闭包能够使用这些常量或者变量。它不关心这些捕获了的变量和常量是否已经超出了作用域,所以只有闭包还在使用它,这些变量就还会存在.

package main

import "fmt"

func main() {
    //返回值为一个匿名函数,返回一个函数类型,通过f来调用返回的匿名函数,f来调用闭包函数
    //它不关心这些捕获了的变量和常量是否已经超出了作用域
    //所以只有闭包还在使用它,这些变量就还会存在。

    f:= test02()
    fmt.Println(f()) //这里相当于调用 test02()
    fmt.Println(f()) //4
    fmt.Println(f()) //9
    fmt.Println(f()) //16
    fmt.Println(f()) //25

    fmt.Println(test01())
    fmt.Println(test01())
    fmt.Println(test01())
    fmt.Println(test01())
}

func test01() int{
    //函数被调用时,x才分配空间,才初始化为0
    var x int //没有初始化,值为0
    x++
    return x * x //函数调用完毕,x自动释放
}

func test02() func() int{
    var x int //没有初始化,值为0

    return func() int {
        x++
        return x*x
    }
}

函数 test02 返回另一个类型为 func() int 的函数。对 test02 的一次调用会生成一个局部变量x并返回一个匿名函数。每次调用时匿名函数时,该函数都会先使x的值加1,再返回x的平方。第二次调用 test02 时,会生成第二个x变量,并返回一个新的匿名函数。新匿名函数操作的是第二个x变量。

通过这个例子,我们看到变量的生命周期不由它的作用域决定:test02 返回后,变量x仍然隐式的存在于f中。

你可能感兴趣的:(go闭包函数的特点)