Go之panic异常捕获处理

背景: 

        在项目开发中我们经常会遇到一个问题那就是,程序处理异常,但是我们捕获到异常又不想 终止整个项目程序,简单点说就是一个业务出现问题,不想影响其他的业务。

下面具体参考相关的代码:

业务代码1连接数据库操作:

func PanicTest2() {

	fmt.Println("测试捕获异常!")
	db, err := gorm.Open("mysql", "root:###@/gcg?charset=utf8&parseTime=True&loc=Local")
	db.SingularTable(true) //默认情况下是创建的表为添加s的表
	if err != nil {
		fmt.Println("连接数据库异常")
		panic(err) //抛出异常
	}
}

具体的业务代码1的处理:

func PanicTest() {
	defer func() {
		if err := recover(); err != nil {
			logger.Info("恐慌异常:", err)
			return
		}
	}()
	PanicTest2()
}

最终的测试用例:

func Test15(t *testing.T) {
	PanicTest()   // 表示业务1
	fmt.Println("下面是其他的业务逻辑")
	fmt.Println("下面是其他的业务逻辑")
}

讲解: 其实GO语言进行异常捕获处理还是很简单的,首先就是写自己的业务逻辑,然后在判断error的地方进行panic(error),然后在业务代码中采用defer 进行recover遍历捕获异常,最后就是可以根据自己的设计对不同的error进行分类处理,可以不作处理,然后就是return返回。

这种方式不会影响其他的业务程序,相关的测试结果如下:

=== RUN   Test15
测试捕获异常!
连接数据库异常
2020-11-26T16:14:06.839+0800	INFO	test/gotmGao_test.go:177	恐慌异常:Error 1045: Access denied for user 'root'@'localhost' (using password: YES)
下面是其他的业务逻辑
下面是其他的业务逻辑

附录:全部测试代码:

func Test15(t *testing.T) {
	PanicTest()   // 表示业务1
	fmt.Println("下面是其他的业务逻辑")
	fmt.Println("下面是其他的业务逻辑")
}

func PanicTest() {
	defer func() {
		if err := recover(); err != nil {
			logger.Info("恐慌异常:", err)
			return
		}
	}()
	PanicTest2()
}
func PanicTest2() {

	fmt.Println("测试捕获异常!")
	db, err := gorm.Open("mysql", "root:###@/gcg?charset=utf8&parseTime=True&loc=Local")
	db.SingularTable(true) //默认情况下是创建的表为添加s的表
	if err != nil {
		fmt.Println("连接数据库异常")
		panic(err) //抛出异常
	}
}

 

上一篇:Rust Lang Book Ch.9 Error Handling


下一篇:内核crash>>>磁盘空间小 怎么处理