最近学习go语言,也写过不少defer,例如socket通信当成功建立连接后立马来一个defer mSocket.Close()亦或是当http建立连接后来一个defer resp.Close(),go defer的引入简直不要太爽,开发者将资源释放的动作放在defer里面,就再不需要过于关注资源释放的问题了。
defer好用是好用,但最近看《go程序设计语言》一书关于defer这一块的介绍时,书中写了一个demo,用defer实现了进入函数的打印以及出函数的打印和函数花费的时间,现把代码贴出来
package main
import (
"log"
"time"
)
func main(){
bigSlowOperation()
}
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() {
log.Printf("enter %s", msg)
start := time.Now()
return func() { log.Printf("exit %s (%s)", msg, time.Since(start)) }
}
仔细一看,发现defer后面是一个函数(方法),而且这个函数的返回值也是函数,按照常规的思维方式,defer修饰的代码应该在函数(方法)

本文探讨了Go语言中defer关键字的使用,特别是涉及到带返回值和不带返回值的函数。通过示例代码展示了defer如何在函数开始和结束时执行不同的操作,解释了带有return的defer函数如何在原函数结束时执行其return语句,而无return的defer则在函数退出时整体执行。
最低0.47元/天 解锁文章

被折叠的 条评论
为什么被折叠?



