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 ,而闭包因为可以保留上次引用的某个值,所以我们传入一次就可以反复使用。