defer 在声明时不会立即执行,而是在函数 return 后,再按照 FILO (先进后出)的原则依次执行每一个 defer,一般用于异常处理、释放资源、清理数据、记录日志等。这有点像面向对象语言的析构函数,优雅又简洁,是 Golang 的亮点之一。
代码1:了解 defer 的执行顺序
package main import "fmt" func fn(n int) int { defer func() { n++ fmt.Println("3st:", n) }() defer func() { n++ fmt.Println("2st:", n) }() defer func() { n++ fmt.Println("1st:", n) }() return n //没有做任何事情 } func main() { fmt.Println("函数返回值:", fn(0)) }输出:
1st: 1
2st: 2
3st: 3
函数返回值: 0
代码2:经典应用实例
func CopyFile(dst, src string) (w int64, err error) { srcFile, err := os.Open(src) if err != nil { return } defer srcFile.Close() //每次申请资源时,请习惯立即申请一个 defer 关闭资源,这样就不会忘记释放资源了 dstFile, err := os.Create(dst) if err != nil { return } defer dstFile.Close() return io.Copy(dstFile, srcFile) }
defer 还有一个重要的特性,就是即便函数抛出了异常,也会被执行的。 这样就不会因程序出现了错误,而导致资源不会释放了。
有疑问加站长微信联系(非本文作者)