背景:
在项目开发中我们经常会遇到一个问题那就是,程序处理异常,但是我们捕获到异常又不想 终止整个项目程序,简单点说就是一个业务出现问题,不想影响其他的业务。
下面具体参考相关的代码:
业务代码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) //抛出异常
}
}