GO語(yǔ)言異常處理機(jī)制panic和recover分析
本文實(shí)例分析了GO語(yǔ)言異常處理機(jī)制panic和recover。分享給大家供大家參考。具體如下:
Golang 有2個(gè)內(nèi)置的函數(shù) panic() 和 recover(),用以報(bào)告和捕獲運(yùn)行時(shí)發(fā)生的程序錯(cuò)誤,與 error 不同,panic-recover 一般用在函數(shù)內(nèi)部。一定要注意不要濫用 panic-recover,可能會(huì)導(dǎo)致性能問(wèn)題,我一般只在未知輸入和不可靠請(qǐng)求時(shí)使用。
golang 的錯(cuò)誤處理流程:當(dāng)一個(gè)函數(shù)在執(zhí)行過(guò)程中出現(xiàn)了異?;蛴龅?panic(),正常語(yǔ)句就會(huì)立即終止,然后執(zhí)行 defer 語(yǔ)句,再報(bào)告異常信息,最后退出 goroutine。如果在 defer 中使用了 recover() 函數(shù),則會(huì)捕獲錯(cuò)誤信息,使該錯(cuò)誤信息終止報(bào)告。
示例:
import (
"log"
"strconv"
)
//捕獲因未知輸入導(dǎo)致的程序異常
func catch(nums ...int) int {
defer func() {
if r := recover(); r != nil {
log.Println("[E]", r)
}
}()
return nums[1] * nums[2] * nums[3] //index out of range
}
//主動(dòng)拋出 panic,不推薦使用,可能會(huì)導(dǎo)致性能問(wèn)題
func toFloat64(num string) (float64, error) {
defer func() {
if r := recover(); r != nil {
log.Println("[W]", r)
}
}()
if num == "" {
panic("param is null") //主動(dòng)拋出 panic
}
return strconv.ParseFloat(num, 10)
}
func main() {
catch(2, 8)
toFloat64("")
}
輸出如下:
2014/11/01 22:54:23 [E] runtime error: index out of range
2014/11/01 22:54:23 [W] param is null
希望本文所述對(duì)大家的GO語(yǔ)言程序設(shè)計(jì)有所幫助。
相關(guān)文章
在Go語(yǔ)言程序中使用gojson來(lái)解析JSON格式文件
這篇文章主要介紹了在Go語(yǔ)言程序中使用gojson來(lái)解析JSON格式文件的方法,Go是由Google開(kāi)發(fā)的高人氣新興編程語(yǔ)言,需要的朋友可以參考下2015-10-10使用docker構(gòu)建golang線上部署環(huán)境的步驟詳解
這篇文章主要介紹了使用docker構(gòu)建golang線上部署環(huán)境的步驟,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧。2017-11-11Golang中slice切片的實(shí)現(xiàn)示例
Go語(yǔ)言中,切片是對(duì)數(shù)組的抽象,提供了更靈活的動(dòng)態(tài)數(shù)組解決方案,本文就來(lái)介紹一下Golang中slice切片的實(shí)現(xiàn)示例,感興趣的可以了解一下2024-09-09Go語(yǔ)言正則表達(dá)式用法實(shí)例小結(jié)【查找、匹配、替換等】
這篇文章主要介紹了Go語(yǔ)言正則表達(dá)式用法,結(jié)合實(shí)例形式分析了Go語(yǔ)言基于正則實(shí)現(xiàn)查找、匹配、替換等基本操作的實(shí)現(xiàn)技巧,需要的朋友可以參考下2017-01-01深入探討Go語(yǔ)言中的預(yù)防性接口為什么是不必要的
在Go語(yǔ)言中,有一種從其他語(yǔ)言帶來(lái)的常見(jiàn)模式:預(yù)防性接口,雖然這種模式在?Java?等語(yǔ)言中很有價(jià)值,但在Go中往往會(huì)成為反模式,本文我們就來(lái)深入探討一下原因2025-01-01