溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

如何理解Go錯(cuò)誤處理之用panic取代rr != nil的模式

發(fā)布時(shí)間:2021-10-21 15:49:28 來源:億速云 閱讀:138 作者:iii 欄目:編程語言

這篇文章主要介紹“如何理解Go錯(cuò)誤處理之用panic取代rr != nil的模式”,在日常操作中,相信很多人在如何理解Go錯(cuò)誤處理之用panic取代rr != nil的模式問題上存在疑惑,小編查閱了各式資料,整理出簡單好用的操作方法,希望對(duì)大家解答”如何理解Go錯(cuò)誤處理之用panic取代rr != nil的模式”的疑惑有所幫助!接下來,請(qǐng)跟著小編一起來學(xué)習(xí)吧!

為什么想替換

在 Go 語言中 if err != nil 寫的太多,還要管方法聲明各種,嫌麻煩又不方便:

err := foo() if err != nil {      //do something..      return err }  err := foo() if err != nil {      //do something..      return err }  err := foo() if err != nil {      //do something..      return err }  err := foo() if err != nil {      //do something..      return err }

上述還是示例代碼,比較直面。若是在工程實(shí)踐,還得各種 package 跳來跳去加 if err != nil,講更繁瑣,要去關(guān)心整體的上下游。

其余更具體的就不贅述了,可以關(guān)注我的公眾號(hào)翻看先前的文章。

怎么替換 err != nil

不想寫 if err != nil 的代碼,方式之一就是用 panic 來替代他。

示例代碼如下:

func GetFish(db *sql.DB, name string) []string {  rows, err := db.Query("select name from users where `name` = ?", name)  if err != nil {   panic(err)  }  defer rows.Close()   var names []string  for rows.Next() {   var name string   err := rows.Scan(&name)   if err != nil {    panic(err)   }    names = append(names, name)  }   err = rows.Err()  if err != nil {   panic(err)  }   return names }

在上述業(yè)務(wù)代碼中,我們通過 panic 的方式取代了 return err 的函數(shù)返回,自然其所關(guān)聯(lián)的下游業(yè)務(wù)代碼也就不需要編寫 if err !=  nil 的代碼:

func main() {  fish2 := GetFish(db, "煎魚")  fish3 := GetFish(db, "咸魚")  fish4 := GetFish(db, "摸魚")  ... }

同時(shí)在轉(zhuǎn)換為使用 panic 模式的錯(cuò)誤機(jī)制后,我們必須要在外層增加 recover 方法:

func AppRecovery() gin.HandlerFunc {  return func(c *gin.Context) {   defer func() {    if err := recover(); err != nil {     if _, ok := err.(AppErr); ok {      // do something...     } else {      panic(err)     }    }   }()  } }

每次 panic 后根據(jù)其拋出的錯(cuò)誤進(jìn)行斷言,識(shí)別是否定制的 AppErr 錯(cuò)誤類型,若是則可以進(jìn)行一系列的處理動(dòng)作。

否則可繼續(xù)向上 panic 拋出給頂級(jí)的 Recovery 方法進(jìn)行處理。

這就是一個(gè)相對(duì)完整的 panic 錯(cuò)誤鏈路處理了。

優(yōu)缺點(diǎn)

  • 從優(yōu)點(diǎn)上來講:

    • 整體代碼結(jié)構(gòu)看起來更加的簡潔,僅專注于實(shí)現(xiàn)邏輯即可。

    • 不需要關(guān)注和編寫冗雜的 if err != nil 的錯(cuò)誤處理代碼。

  • 從缺點(diǎn)上來講:

    • 認(rèn)知負(fù)擔(dān)的增加,需要參加項(xiàng)目的每一個(gè)新老同學(xué)都清楚該模式,要做一個(gè)基本規(guī)范或培訓(xùn)。

    • 存在一定的性能開銷,每次 panic 都存在用戶態(tài)的上下文切換。

    • 存在一定的風(fēng)險(xiǎn)性,一旦 panic 沒有 recover 住,就會(huì)導(dǎo)致事故。

    • Go 官方并不推薦,與 panic 本身的定義相違背,也就是 panic 與 error 的概念混淆。

到此,關(guān)于“如何理解Go錯(cuò)誤處理之用panic取代rr != nil的模式”的學(xué)習(xí)就結(jié)束了,希望能夠解決大家的疑惑。理論與實(shí)踐的搭配能更好的幫助大家學(xué)習(xí),快去試試吧!若想繼續(xù)學(xué)習(xí)更多相關(guān)知識(shí),請(qǐng)繼續(xù)關(guān)注億速云網(wǎng)站,小編會(huì)繼續(xù)努力為大家?guī)砀鄬?shí)用的文章!

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請(qǐng)聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI