一旦mayPanic触发了panic,控制流会跳到defer函数中,尝试执行recover。
如果recover捕获到了panic,它会阻止panic继续传播,程序控制流会继续在safeCall函数的defer函数之后进行。
然而,由于panic导致的提前返回,safeCall中defer之后的代码(如打印"function executed successfully")不会被执行
package main
import (
"fmt"
"log"
)
func mayPanic() {
// 模拟一个可能引发panic的操作
panic("something bad happened")
}
func safeCall() {
// 使用defer结合匿名函数和recover来捕获panic
defer func() {
if r := recover(); r != nil {
// 捕获到panic,打印错误信息
log.Printf("Recovered from panic: %v\n", r)
}
}()
mayPanic()
// 如果没有发生panic,这行代码会被执行
// 但实际上,由于mayPanic中发生了panic,这行代码不会执行
fmt.Println("This message will not be printed if panic occurred")
}
func main() {
safeCall()
// 程序继续执行,没有崩溃
fmt.Println("Program continues to execute after recover.")
}