GO语言延迟函数defer用法分析
2016-11-16 15:04
1031 查看
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 还有一个重要的特性,就是即便函数抛出了异常,也会被执行的。 这样就不会因程序出现了错误,而导致资源不会释放了。
代码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 还有一个重要的特性,就是即便函数抛出了异常,也会被执行的。 这样就不会因程序出现了错误,而导致资源不会释放了。
相关文章推荐
- GO语言延迟函数defer用法分析
- GO语言Defer用法实例分析
- Go语言中slice的用法实例分析
- GO语言映射(Map)用法分析
- Go语言中的range用法实例分析
- Go语言中的方法定义用法分析
- go语言的defer用法学习
- Go语言map用法实例分析
- Go语言map字典用法实例分析
- Go语言字典(map)用法实例分析【创建,填充,遍历,查找,修改,删除】
- Go语言中的延迟函数defer示例详解
- Go语言中append函数用法分析
- Go语言Cookie用法分析
- go语言接口用法实例分析
- Go语言中的switch用法实例分析
- 你猜对了么?一个函数考察Go 语言闭包、defer的用法
- Go语言里的new函数用法分析
- Go语言截取字符串函数用法
- Go语言中struct的匿名属性特征实例分析
- GO语言异常处理机制panic和recover分析