golang学习笔记---闭包

package main

import (
    "fmt"
)

// 累加器
//    AddUpper:方法名    func (int) int:返回值类型列表
func AddUpper() func(int) int {
    var n int = 10
    return func(x int) int {
        n = n + x
        return n
    }
}

// 闭包案例演示
func main() {
    // 使用累加器
    f := AddUpper()

    fmt.Println(f(1)) // 11
    fmt.Println(f(2)) // 13
    fmt.Println(f(3)) // 16
}

 对上面代码的说明和总结:

1) AddUpper 是一个函数,返回的数据类型是 fun (int) int

2) 闭包的说明

返回的是一个匿名函数, 但是这个匿名函数引用到函数外的 n(当做一个全局变量来理解即可) ,因此这个匿名函数就和 n 形成一个整体,构成闭包。

3) 大家可以这样理解: 闭包是类, 函数是操作,n 是字段。函数和它使用到 n 构成闭包。

4) 当我们反复的调用 f 函数时,因为 n 只初始化一次,因此每调用一次就进行累计。

5) 我们要搞清楚闭包的关键,就是要分析出返回的函数它使用(引用)到哪些变量,因为函数和它引用到的变量共同构成闭包。

6) 对上面代码的一个修改,加深对闭包的理解

package main
import (
    "fmt"
    "strings"
)

func makeSuffix(suffix string) func (string) string {
    return func (name string) string {
        // 如果 name 没有指定后缀,则加上,否则直接返回
        if !strings.HasSuffix(name, suffix) {
            return name + suffix
        }
        return name
    }
}

// 闭包案例演示
func main() {
    // 返回一个闭包
    f2 := makeSuffix(".jpg")
    fmt.Println("文件处理后 = ", f2("winter"))         // winter.jpg
    fmt.Println("文件处理后 = ", f2("soldier.jpg"))    // soldier.jpg
}

上面代码的总结和说明:

1) 返回的匿名函数和 makeSuffix (suffix string) 的 suffix 变量 组合成一个闭包,因为返回的函数引用到 suffix 这个变量

2) 我们体会一下闭包的好处,如果使用传统的方法,也可以轻松实现这个功能,但是传统方法需要每次都传入后缀名,比如 .jpg ,而闭包因为可以保留上次引用的某个值,所以我们传入一次就可以反复使用

原文地址:https://www.cnblogs.com/saryli/p/13551836.html