对于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
结束时,执行延后函数,计算执行的耗时。
原文地址:https://www.cnblogs.com/lanyangsh/p/11047143.html
时间: 2024-10-01 06:23:16