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
}
posted @ 2024-11-11 08:57  CHHC  阅读(13)  评论(0编辑  收藏  举报