Go panic 和 defer 的完美组合使用
让我们回想一下 Go Panic 是什么 。 当一个函数遇到 panic 时,它的执行会停止,任何 defer 函数 都会被执行,然后控制权返回给它的调用者。 这个过程一直持续到当前 goroutine 的所有函数都已经返回,此时程序会打印 panic 消息,然后是堆栈跟踪,最后终止。
在 Go Panic 用法详解 那篇文章中的示例,我们没有延迟任何函数调用。 如果存在延迟函数调用,则执行它,然后控制返回到其调用者。
现在让我们使用 defer 重新改写先前那个示例
package main
import (
"fmt"
)
funcfullName(firstName *string, lastName *string) {
defer fmt.Println("deferred call in fullName")
if firstName == nil {
panic("runtime error: first name cannot be nil")
}
if lastName == nil {
panic("runtime error: last name cannot be nil")
}
fmt.Printf("%s %s\n", *firstName, *lastName)
fmt.Println("returned normally from fullName")
}
funcmain() {
defer fmt.Println("deferred call in main")
firstName := "Elon"
fullName(&firstName, nil)
fmt.Println("returned normally from main")
}
运行示例
所做的唯一更改是添加了延迟函数调用。
上面程序输出如下
当程序遇到 Panic 时。 首先执行任何延迟的函数调用,然后控制返回到执行延迟调用的调用者,依此类推,直到到达顶级调用者。
在我们的例子中,fullName
函数的 defer
语句先执行。 这将打印以下消息。
deferred call in fullName
然后控制返回到执行延迟调用的主函数,打印如下消息
deferred call in main
现在已经到达顶级函数,因此程序打印 Panic 消息,然后是堆栈跟踪,最后终止。
本文转载自:迹忆客(https://www.jiyik.com)
以上是 Go panic 和 defer 的完美组合使用 的全部内容, 来源链接: utcz.com/z/290240.html