码迷,mamicode.com
首页 > 编程语言 > 详细

go语言中的try、catch、throw实现

时间:2021-05-24 00:20:08      阅读:0      评论:0      收藏:0      [点我收藏+]

标签:string   call   return   mssql   mss   recover   不能   defer   turn   

func (o *MsSqlUtils) ExecuteSql(cmd string) (err1 error, affected int64) {
defer func() { //必须要先声明defer,否则不能捕获到panic异常
if err2 := recover(); err2 != nil {
err1 = fmt.Errorf("internal error: %v", err2)
}
}()
stmt, err := o.Db.Prepare(cmd)
checkErr(err)
var res sql.Result
res, err1 = stmt.Exec()
checkErr(err1)
if err1 != nil {
affected, err1 = res.RowsAffected()
}
return
}
函数中的defer中调用了recover(),获取错误,并作为函数的返回值。

go中很多函数有error类型的返回值,如果希望以异常的形式抛出,可以调用panic让recover函数捕获,如:

func (o *MsSqlUtils) ExecuteWithTrans(callback TransCallback) (err1 error) {
defer func() { //必须要先声明defer,否则不能捕获到panic异常
if err2 := recover(); err2 != nil {
err1 = fmt.Errorf("internal error: %v", err2)
}
}()
trans, _ := o.Db.Begin()
err := callback(o)
if err == nil {
trans.Commit()
} else {
trans.Rollback()
panic(err)
}
return
}

go语言中的try、catch、throw实现

标签:string   call   return   mssql   mss   recover   不能   defer   turn   

原文地址:https://www.cnblogs.com/cheyunhua/p/14738390.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!