分享
Golang中defer、闭包以及命名返回值
永遠的草莓地 · · 2318 次点击 · · 开始浏览这是一个创建于 的文章,其中的信息可能已经有所发展或是发生改变。
defer 后面跟普通函数
package main
func main() {
run()
}
func run() {
name := "Paul"
defer sayHello(name)
name = "John"
}
func sayHello(name string) {
println("Hello " + name)
}
// Hello Paul 只是延缓执行,实参会按照正常顺序传入函数中
defer、return 和未命名的返回值
package main
func main() {
name := run()
println("return: name = " + name)
}
func run() (string) {
name := "Paul"
defer sayHello(&name)
name = "John"
return name
}
func sayHello(name *string) {
*name = "George"
println("Hello " + *name)
}
//Hello John 虽然实参提前传入,但是传入的是一个指针,最后执行拿到的是经过修改过的值
//Hello George
//return: name = John 未命名返回值,所以 defer 无法对返回的值进行操作的
defer、return 和命名的返回值
package main
func main() {
name := run()
println("return: name = " + name)
func run() (x string) {
name := "Paul"
x = name
defer sayHello(&x)
name = "John"
return name
}
func sayHello(name *string) {
println("Hello " + *name)
*name = "George"
println("Hello " + *name)
}
//Hello John
//Hello George
//return: name = George 因为使用命名返回值,所 defer 里面依然可以对 defer 进行操作
package main
func main() {
name := run()
println("return: name = " + name)
func run() (x string) {
name := "Paul"
x = name
defer sayHello(x)
name = "John"
return name
}
func sayHello(name string) {
println("Hello " + name)
name = "George"
println("Hello " + name)
}
//Hello Paul 延迟执行但是按照程序顺序执行,传入的实参为 Paul
//Hello George 函数内修改对外面的值没有影响
//return: name = John
defer 闭包函数
package main
func main() {
name := run()
println("return: name = " + name)
}
func run() (string) {
name := "Paul"
aFun := func() {
println("Hello " + name)
name = "George"
println("Hello " + name)
}
name = "John"
aFun()
return name
}
//Hello John 虽然闭包定义时,外部变量 name = "Paul", 但是其实只是记录是一个指针,所以最后执行的时候 name = "John"
//Hello George
//return: name = George
package main
func main() {
name := run()
println("return: name = " + name)
}
func run() (x string) {
name := "Paul"
aFun := func() {
println("Hello " + x)
x = "George"
println("Hello " + x)
}
defer aFun()
name = "John"
return name
}
//Hello John
//Hello George
//return: name = George defer 对返回值进行了修改
package main
func main() {
name := run()
println("return: name = " + name)
}
func run() (x string) {
name := "Paul"
x = name
aFun := func(x string) {
println("Hello " + x)
x = "George"
println("Hello " + x)
}
defer aFun(x)
name = "John"
return name
}
//Hello Paul 实参按照顺序拷贝传入 x = "Paul"
//Hello George
//return: name = John 因为设置了形参所以闭包内的对应的变量只是在局部生效,不会影响外部变量
有疑问加站长微信联系(非本文作者)
入群交流(和以上内容无关):加入Go大咖交流群,或添加微信:liuxiaoyan-s 备注:入群;或加QQ群:692541889
关注微信2318 次点击
上一篇:2018年Go语言实战笔记1
添加一条新回复
(您需要 后才能回复 没有账号 ?)
- 请尽量让自己的回复能够对别人有帮助
- 支持 Markdown 格式, **粗体**、~~删除线~~、
`单行代码` - 支持 @ 本站用户;支持表情(输入 : 提示),见 Emoji cheat sheet
- 图片支持拖拽、截图粘贴等方式上传
收入到我管理的专栏 新建专栏
defer 后面跟普通函数
package main
func main() {
run()
}
func run() {
name := "Paul"
defer sayHello(name)
name = "John"
}
func sayHello(name string) {
println("Hello " + name)
}
// Hello Paul 只是延缓执行,实参会按照正常顺序传入函数中
defer、return 和未命名的返回值
package main
func main() {
name := run()
println("return: name = " + name)
}
func run() (string) {
name := "Paul"
defer sayHello(&name)
name = "John"
return name
}
func sayHello(name *string) {
*name = "George"
println("Hello " + *name)
}
//Hello John 虽然实参提前传入,但是传入的是一个指针,最后执行拿到的是经过修改过的值
//Hello George
//return: name = John 未命名返回值,所以 defer 无法对返回的值进行操作的
defer、return 和命名的返回值
package main
func main() {
name := run()
println("return: name = " + name)
func run() (x string) {
name := "Paul"
x = name
defer sayHello(&x)
name = "John"
return name
}
func sayHello(name *string) {
println("Hello " + *name)
*name = "George"
println("Hello " + *name)
}
//Hello John
//Hello George
//return: name = George 因为使用命名返回值,所 defer 里面依然可以对 defer 进行操作
package main
func main() {
name := run()
println("return: name = " + name)
func run() (x string) {
name := "Paul"
x = name
defer sayHello(x)
name = "John"
return name
}
func sayHello(name string) {
println("Hello " + name)
name = "George"
println("Hello " + name)
}
//Hello Paul 延迟执行但是按照程序顺序执行,传入的实参为 Paul
//Hello George 函数内修改对外面的值没有影响
//return: name = John
defer 闭包函数
package main
func main() {
name := run()
println("return: name = " + name)
}
func run() (string) {
name := "Paul"
aFun := func() {
println("Hello " + name)
name = "George"
println("Hello " + name)
}
name = "John"
aFun()
return name
}
//Hello John 虽然闭包定义时,外部变量 name = "Paul", 但是其实只是记录是一个指针,所以最后执行的时候 name = "John"
//Hello George
//return: name = George
package main
func main() {
name := run()
println("return: name = " + name)
}
func run() (x string) {
name := "Paul"
aFun := func() {
println("Hello " + x)
x = "George"
println("Hello " + x)
}
defer aFun()
name = "John"
return name
}
//Hello John
//Hello George
//return: name = George defer 对返回值进行了修改
package main
func main() {
name := run()
println("return: name = " + name)
}
func run() (x string) {
name := "Paul"
x = name
aFun := func(x string) {
println("Hello " + x)
x = "George"
println("Hello " + x)
}
defer aFun(x)
name = "John"
return name
}
//Hello Paul 实参按照顺序拷贝传入 x = "Paul"
//Hello George
//return: name = John 因为设置了形参所以闭包内的对应的变量只是在局部生效,不会影响外部变量