網(wǎng)站首頁(yè) 編程語(yǔ)言 正文
錯(cuò)誤
Go 語(yǔ)言通過(guò)內(nèi)置的錯(cuò)誤接口提供了非常簡(jiǎn)單的錯(cuò)誤處理機(jī)制,Error 類型是一個(gè)接口類型。
type error interface { Error() string }
可以在編碼中通過(guò)實(shí)現(xiàn) error 接口類型來(lái)生成錯(cuò)誤信息。
函數(shù)通常在最后的返回值中返回錯(cuò)誤信息。
// 定義一個(gè) DivideError 結(jié)構(gòu) type DivideError struct { dividee int divider int } // 實(shí)現(xiàn) `error` 接口 func (de *DivideError) Error() string { strFormat := ` Cannot proceed, the divider is zero. dividee: %d divider: 0 ` return fmt.Sprintf(strFormat, de.dividee) } func Divide(varDividee int, varDivider int) (result int, errorMsg string) { if varDivider == 0 { dData := DivideError{ dividee: varDividee, divider: varDivider, } errorMsg = dData.Error() return } else { return varDividee / varDivider, "" } }
Divide 函數(shù)傳入除數(shù)和被除數(shù),當(dāng)被除數(shù)為零時(shí),函數(shù)拋出異常。
if result, errorMsg := Divide(100, 10); errorMsg == "" { fmt.Println(result) }
這是正常情況下。
當(dāng)除數(shù)為零的時(shí)候會(huì)返回錯(cuò)誤信息。
if _, errorMsg := Divide(100, 0); errorMsg != "" { fmt.Println("errorMsg is: ", errorMsg) }
異常
Go的類型系統(tǒng)會(huì)在編譯時(shí)捕獲很多錯(cuò)誤,但有些錯(cuò)誤只能在運(yùn)行時(shí)檢查,如數(shù)組訪問(wèn)越界、空指針引用等。這些運(yùn)行時(shí)錯(cuò)誤會(huì)引起painc異常。
當(dāng)程序發(fā)生異常時(shí),無(wú)法繼續(xù)運(yùn)行,使用?panic
?來(lái)終止程序。
應(yīng)該盡可能地使用錯(cuò)誤,而不是使用?panic
?和?recover
?。只有當(dāng)程序不能繼續(xù)運(yùn)行的時(shí)候,才應(yīng)該使用?panic
?和?recover
?機(jī)制。
panic
?有兩個(gè)合理的用例:
- 發(fā)生了一個(gè)不能恢復(fù)的錯(cuò)誤,此時(shí)程序不能繼續(xù)運(yùn)行。
- 發(fā)生了一個(gè)編程上的錯(cuò)誤。一個(gè)接收指針參數(shù)的方法,而其他人使用?
nil
?作為參數(shù)調(diào)用了它。在這種情況下,可以使用?panic
?,因?yàn)檫@是一個(gè)編程錯(cuò)誤:用?nil
?參數(shù)調(diào)用了一個(gè)只能接收合法指針的方法。
內(nèi)建函數(shù)?panic
:
func panic(v interface{})
當(dāng)程序終止時(shí),會(huì)打印傳入?panic
?的參數(shù)。
package main func main() { panic("panic error") }
會(huì)打印出傳入?panic
?函數(shù)的信息,并打印出堆棧跟蹤。
recover
?是一個(gè)內(nèi)建函數(shù),用于重新獲得?panic
?協(xié)程的控制。
func recover() interface{}
recover
?必須在?defer
?函數(shù)中才能生效,在延遲函數(shù)內(nèi)調(diào)用?recover
?,可以取到?panic
?的錯(cuò)誤信息,并且停止?panic
?續(xù)發(fā)事件。只有在相同的協(xié)程中調(diào)用?recover
?才管用,?recover
?不能恢復(fù)一個(gè)不同協(xié)程的?panic
?。
package main import "fmt" func outOfArray(x int) { defer func() { // recover() 可以將捕獲到的 panic 信息打印 if err := recover(); err != nil { fmt.Println(err) } }() var array [5]int array[x] = 1 } func main() { // 故意制造數(shù)組越界 觸發(fā) panic outOfArray(20) // 如果能執(zhí)行到這句 說(shuō)明 panic 被捕獲了 // 后續(xù)的程序能繼續(xù)運(yùn)行 fmt.Println("main...") }
總結(jié)
原文鏈接:https://juejin.cn/post/7123831661782892581
相關(guān)推薦
- 2022-05-22 基于jQuery排序及應(yīng)用實(shí)現(xiàn)Tab欄特效_jquery
- 2022-11-14 React中的生命周期詳解_React
- 2022-07-11 Pandas常用累計(jì)、同比、環(huán)比等統(tǒng)計(jì)方法實(shí)踐過(guò)程_python
- 2023-09-12 gradle和maven打包時(shí)排除application.properties
- 2022-06-06 typescript中abstractClass(抽象類)、extends、abstract
- 2022-08-31 Python無(wú)法用requests獲取網(wǎng)頁(yè)源碼的解決方法_python
- 2022-06-30 C語(yǔ)言詳細(xì)圖解浮點(diǎn)型數(shù)據(jù)的存儲(chǔ)實(shí)現(xiàn)_C 語(yǔ)言
- 2022-08-15 python?time模塊時(shí)間戳?與?結(jié)構(gòu)化時(shí)間詳解_python
- 最近更新
-
- window11 系統(tǒng)安裝 yarn
- 超詳細(xì)win安裝深度學(xué)習(xí)環(huán)境2025年最新版(
- Linux 中運(yùn)行的top命令 怎么退出?
- MySQL 中decimal 的用法? 存儲(chǔ)小
- get 、set 、toString 方法的使
- @Resource和 @Autowired注解
- Java基礎(chǔ)操作-- 運(yùn)算符,流程控制 Flo
- 1. Int 和Integer 的區(qū)別,Jav
- spring @retryable不生效的一種
- Spring Security之認(rèn)證信息的處理
- Spring Security之認(rèn)證過(guò)濾器
- Spring Security概述快速入門
- Spring Security之配置體系
- 【SpringBoot】SpringCache
- Spring Security之基于方法配置權(quán)
- redisson分布式鎖中waittime的設(shè)
- maven:解決release錯(cuò)誤:Artif
- restTemplate使用總結(jié)
- Spring Security之安全異常處理
- MybatisPlus優(yōu)雅實(shí)現(xiàn)加密?
- Spring ioc容器與Bean的生命周期。
- 【探索SpringCloud】服務(wù)發(fā)現(xiàn)-Nac
- Spring Security之基于HttpR
- Redis 底層數(shù)據(jù)結(jié)構(gòu)-簡(jiǎn)單動(dòng)態(tài)字符串(SD
- arthas操作spring被代理目標(biāo)對(duì)象命令
- Spring中的單例模式應(yīng)用詳解
- 聊聊消息隊(duì)列,發(fā)送消息的4種方式
- bootspring第三方資源配置管理
- GIT同步修改后的遠(yuǎn)程分支