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) //抛出异常
	}
}

 

  • 2
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值