golang异常处理trycatch,确保系统不崩溃
package main
import (
"fmt"
"os"
"os/signal"
"syscall"
)
func test0() {
defer func() {
if r := recover(); r != nil { // 捕获 panic
fmt.Printf("Caught in tryCatch: %v\n", r)
}
}()
panic("test0")
}
func test1() {
panic("test1")
}
func test2() {
panic("test2")
}
func test3() {
tryCatch(func() {
test1()
})
}
// tryCatch 封装了 panic 恢复机制
func tryCatch(fn func()) {
defer func() {
if r := recover(); r != nil { // 捕获 panic
fmt.Printf("Caught in tryCatch: %v\n", r)
}
}()
fn() // 执行传入的函数
}
func main() {
// 默认的处理方式
test0()
// 封装后
// 模拟在外部catch
tryCatch(func() {
test1()
})
// go tryCatch(func() {
// test2()
// })
// 模拟在内部catch
test3()
// 模拟方法内异常捕获,一个有异常,跳到catch
tryCatch(func() {
test1()
test2()
test3()
})
// 输出结果
// Caught in tryCatch: test0
// Caught in tryCatch: test1
// Caught in tryCatch: test1
// Caught in tryCatch: test1
// 监听操作系统信号,阻塞直到接收到信号
quit := make(chan os.Signal, 1)
signal.Notify(quit, syscall.SIGINT, syscall.SIGTERM)
<-quit
}
qq:505645074