golang defer 延后执行什么
Posted lanyangsh
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了golang defer 延后执行什么相关的知识,希望对你有一定的参考价值。
对于golang的defer,我们已经知道,defer定义的语句可以延后到函数返回时执行。
经常用在文件的关闭,锁的释放等场景中。而且defer定义的语句即使遇到panic也会执行。这样,可以执行必要的清理工作,甚至使用recover()
捕获异常。
以前使用defer经常这样用:
defer close()
或者
defer func()
//do something...
()
本文介绍defer使用函数返回值(也是函数)作为延后执行内容时的情况。
请看例子代码:
package main
import (
"fmt"
)
func main()
a()
func a()
defer b()()
fmt.Println("a...")
func b() func()
fmt.Println("b...")
return func()
fmt.Println("last...")
这个例子很简单,只有几行代码。
对于defer的认识,
以前的误解是:
defer b()()
中的b()
也是延后执行的。
而实际情况是:
执行defer b()()
语句时,会去执行b()
, 而b()
返回的函数延后执行。
输出的结果是:
b...
a...
last...
这种用法已经在《Go语言圣经》中提到,具体例子代码如下:
//gopl.io/ch5/trace
func bigSlowOperation()
defer trace("bigSlowOperation")() // don't forget the extra parentheses
// ...lots of work...
time.Sleep(10 * time.Second) // simulate slow operation by sleeping
func trace(msg string) func()
start := time.Now()
log.Printf("enter %s", msg)
return func()
log.Printf("exit %s (%s)", msg,time.Since(start))
defer定义时,开始计时,等bigSlowOperation
结束时,执行延后函数,计算执行的耗时。
以上是关于golang defer 延后执行什么的主要内容,如果未能解决你的问题,请参考以下文章