Go 语言函数闭包
Go 语言支持匿名函数,可作为闭包。匿名函数是一个"内联"语句或表达式。匿名函数的优越性在于可以直接使用函数内的变量,不必申明。
以下实例中,我们创建了函数 getSequence() ,返回另外一个函数。该函数的目的是在闭包中递增 i 变量,代码如下:
实例
package main
import "fmt"
func getSequence() func() int {
i:=0
return func() int {
i+=1
return i
}
}
func main(){
/* nextNumber 为一个函数,函数 i 为 0 */
nextNumber := getSequence()
/* 调用 nextNumber 函数,i 变量自增 1 并返回 */
fmt.Println(nextNumber())
fmt.Println(nextNumber())
fmt.Println(nextNumber())
/* 创建新的函数 nextNumber1,并查看结果 */
nextNumber1 := getSequence()
fmt.Println(nextNumber1())
fmt.Println(nextNumber1())
}
import "fmt"
func getSequence() func() int {
i:=0
return func() int {
i+=1
return i
}
}
func main(){
/* nextNumber 为一个函数,函数 i 为 0 */
nextNumber := getSequence()
/* 调用 nextNumber 函数,i 变量自增 1 并返回 */
fmt.Println(nextNumber())
fmt.Println(nextNumber())
fmt.Println(nextNumber())
/* 创建新的函数 nextNumber1,并查看结果 */
nextNumber1 := getSequence()
fmt.Println(nextNumber1())
fmt.Println(nextNumber1())
}
以上代码执行结果为:
1 2 3 1 2
Go 函数
JansonLv
jan***lv@qq.com
带参数的闭包函数调用:
package main import "fmt" func main() { add_func := add(1,2) fmt.Println(add_func()) fmt.Println(add_func()) fmt.Println(add_func()) } // 闭包使用方法 func add(x1, x2 int) func()(int,int) { i := 0 return func() (int,int){ i++ return i,x1+x2 } }JansonLv
jan***lv@qq.com
涂荼
104***3730@163.com
闭包带参数补充:
package main import "fmt" func main() { add_func := add(1,2) fmt.Println(add_func(1,1)) fmt.Println(add_func(0,0)) fmt.Println(add_func(2,2)) } // 闭包使用方法 func add(x1, x2 int) func(x3 int,x4 int)(int,int,int) { i := 0 return func(x3 int,x4 int) (int,int,int){ i++ return i,x1+x2,x3+x4 } }涂荼
104***3730@163.com
poppowerlb2
209***340@qq.com
闭包带参数继续补充:
package main import "fmt" // 闭包使用方法,函数声明中的返回值(闭包函数)不用写具体的形参名称 func add(x1, x2 int) func(int, int) (int, int, int) { i := 0 return func(x3, x4 int) (int, int, int) { i += 1 return i, x1 + x2, x3 + x4 } } func main() { add_func := add(1, 2) fmt.Println(add_func(4, 5)) fmt.Println(add_func(1, 3)) fmt.Println(add_func(2, 2)) }poppowerlb2
209***340@qq.com
最近很帅
kai***gtingting@qq.com
fmt.Println(nextNumber()) 这一章没有讲清楚啊 ,例子也少了一行代码,补充上去。
package main import "fmt" func getSequence() func() int { i := 0 return func() int { i += 1 return i } } func main() { /* nextNumber 为一个函数,函数 i 为 0 */ nextNumber := getSequence() /* 调用 nextNumber 函数,i 变量自增 1 并返回 */ fmt.Println(nextNumber()) //这个执行结果是1 fmt.Println(nextNumber()) //这个执行结果是2 fmt.Println(nextNumber()) //这个执行结果是3 /* 创建新的函数 nextNumber1,并查看结果 */ nextNumber1 := getSequence() //当getSequence()被重新赋值之后,nextNumber的值应该销毁丢失的,但并没有 fmt.Println(nextNumber1()) //这儿因为是新赋值的,所以是1 fmt.Println(nextNumber()) //这一行代码是补充上例子的。这儿可不是新赋的值,重点说明这一个,这儿执行居然是4,这个值并没有被销毁,原因就是闭包导致的,尽管外面的函数销毁了,但是内部函数仍然存在,还可以继续走。这个就是闭包 fmt.Println(nextNumber1()) //新赋值的,继续执行是2 }打印出来的结果是:
解释一下为什么会这样,这是所有有回调函数的语言都会存在的情况,这个就是闭包。
最近很帅
kai***gtingting@qq.com