package main
import (
"fmt"
"runtime"
)
func f1() {
fmt.Println("run f1")
}
func PrintStack() {
var buf [4096]byte
n := runtime.Stack(buf[:], false)
fmt.Printf("==> %s\n", string(buf[:n]))
}
func f2() {
fmt.Println("run f2")
defer func(){
err := recover()
fmt.Println(err)
PrintStack()
fmt.Println("释放数据库连接...")
}()
a:=1
b := 100/a
panic("出现严重错误!")
fmt.Println("run after"+string(b))
}
func f3() {
fmt.Println("run f3")
}
func main() {
f1()
f2()
f3()
}
go 异常打印
最新推荐文章于 2025-02-25 11:14:06 发布
本文深入探讨了Go语言中的panic和recover机制。在f2函数中,通过触发panic展示了错误处理流程,然后使用recover捕获异常并打印错误信息。PrintStack函数用于打印堆栈跟踪,帮助定位问题。最后,文章强调了资源释放的重要性,如数据库连接,在异常发生后的清理工作。
2047

被折叠的 条评论
为什么被折叠?



