Golang - 访问数据库报错后程序继续运行

 

1、问题缘由

在学习golang的时候,发现panic挺好用,但是有一个问题,比如执行update数据库,会报错faminly字段不存在,然后golang主程序直接退出了,没有找到类似try catch exception的方式,让我不得其解。后来网上请教golang高手,得知问题出在这里:Golang处理异常是用error返回的方式,然后调用方根据error的值走不同的处理逻辑。但是,如果程序触发其他的严重异常,比如说数组越界,程序就要直接崩溃。关于这种问题,可以考虑使用defer、panic、recover联合使用来解决

 

2、关于Defer、Panic、Recover


Defer
Defer语句将一个函数放入一个列表(用栈表示其实更准确)中,该列表的函数在环绕defer的函数返回时会被执行。defer通常用于简化函数的各种各样清理动作,例如关闭文件,解锁等等的释放资源的动作。
Panic
Panic是内建的停止控制流的函数。相当于其他编程语言的抛异常操作。当函数F调用了panic,F的执行会被停止,在F中panic前面定义的defer操作都会被执行,然后F函数返回。对于调用者来说,调用F的行为就像调用panic(如果F函数内部没有把panic recover掉)。如果都没有捕获该panic,相当于一层层panic,程序将会crash。panic可以直接调用,也可以是程序运行时错误导致,例如数组越界。

Recover
Recover是一个从panic恢复的内建函数。Recover只有在defer的函数里面才能发挥真正的作用。如果是正常的情况(没有发生panic),调用recover将会返回nil并且没有任何影响。如果当前的goroutine panic了,recover的调用将会捕获到panic的值,并且恢复正常执行。

 

3、问题解决

一个专门处理异常错误的方法:
func check_eorr(err error,exesql string){
   defer func() {

      if r := recover(); r != nil {
         fmt.Printf("get error infomation:%s\n", r)
      }
   }()

   if err != nil {
      fmt.Println("query or exec error:",exesql)
      panic(err)

   }
}

 

使用的时候这样用:

func insert_data(){
   age:=20
   exesql:="SELECT name FROM users WHERE age= '"+age+"'"
   rows, err := db.Query(exesql)
   // 调用错误处理方法check_error
   check_eorr(err,exesql)
}

 

评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值