前言
在go语言中不存在try catch异常处理逻辑,而我们可以使用panic recover defer来程序执行流程,借此来达到异常处理的目的。
Panic是一个可以停止程序执行流程的内置函数。 假设当前F函数当中某处代码触发panic函数,则F函数停止后面代码的执行,转而执行F函数内部的defer函数(前提已经声明了defer函数),然后结束F函数,将当前处理权转给F的调用函数。若果F的调用函数没有recover捕捉异常,则会一直向上传递,直到main函数里,该调用者会终止执行。如果F的调用函数使用recover捕捉异常,则F的调用者的调用者会继续执行。
panic结束没有返回值,对于F的调用方M来说,F是调用panic函数结束的,而不是执行return结束的。
案例
注意:1.调用panic后,调用方函数执行从当前调用点退出。2.recover函数只有在defer代码块中才会有效果。
func main() {
f()
fmt.Println("Returned normally from f.")//正常执行
}
func f() {
defer func() {
if r := recover(); r != nil {
fmt.Println("Recovered in f", r)
}
}()
fmt.Println("Calling g.")
g(1)
fmt.Println("Returned normally from g.")//会终止执行
}
func g(i int) {
defer fmt.Println("Defer in g", i)
fmt.Println("Panicking!")
panic(fmt.Sprintf("%v", i))
fmt.Println("Printing in g", i)//终止执行
}
以上会输出
Calling g.
Panicking!
Defer in g 1
Recovered in f 1
Returned normally from f.