GO 之匿名函数、闭包

匿名函数

go语言支持匿名函数,即像普通变量一样被引用或者传递

func main(){
    var v func(a int) int
    v = func(a int) int {
    return a*a
    }
    fmt.Println(v(5))
    //另一种写法
    s := func(a int) int {
        return a*a
    }
    fmt.Println(s(7))
}

GO语言的匿名函数就是闭包,《go语言编程》中对闭包的解释是:

基本概念
闭包是:可以包含自由(未绑定到特定对象)变量的代码块,这些变量不在这个代码块内或者任何全局上下文中定义,而是在定义代码块的环境中定义。要执行的代码块(由于自由变量包含在代码块中,所以这些自由变量以及它们引用的对象没有被释放)为自由变量提供绑定的计算环境(作用域)。
 闭包的价值
闭包的价值在于:可以作为函数对象或者匿名函数,对于类型系统而言,这意味着不仅要表示数据还要表示代码。支持闭包的多数语言都将函数作为第一级对象,就是说这些函数可以存储到变量中作为参数传递给其他函数,最重要的是能够被函数动态创建和返回。

强调下:

闭包就是函数和其引用的相关环境,组成的实体

直接在定义变量的时候就直接把函数也定义好了,函数也就是变量,这个官方的解释真麻烦,不知带到底有没有人能懂

package main

import "fmt"

func main() {
    var f = Adder()
    fmt.Println(f(1), "-")
    fmt.Println(f(20), "-")
    fmt.Println(f(300), "-")

}
func Adder() func(int) int {
    var x int
    return func(delta int) int {
        x += delta
        return x
    }
}

示例:

测试文件后缀的闭包

package main

import (
    "fmt"
    "strings"
)

func makeSuffix(suffix string) func(string) string {
    return func(name string) string {
        if strings.HasSuffix(name, suffix) == false {
            return name + suffix
        }
        return name
    }
}

func main() {
    //判断字符串 以bmp结尾
    f1 := makeSuffix(".bmp")
    fmt.Println(f1("test"))
    fmt.Println(f1("pic"))
    f2 := makeSuffix(".jpg")
    fmt.Println(f2("test"))
    fmt.Println(f2("pic"))
}

 

猜你喜欢

转载自www.cnblogs.com/wangyuxing/p/10422612.html