您好,登錄后才能下訂單哦!
golang中異常處理的使用場景有哪些?針對這個問題,這篇文章給出了相對應的分析和解答,希望能幫助更多想解決這個問題的朋友找到更加簡單易行的辦法。
例子代碼:
package main import "fmt" func main(){ defer func(){ // 必須要先聲明defer,否則不能捕獲到panic異常 fmt.Println("c") if err:=recover();err!=nil{ fmt.Println(err) // 這里的err其實就是panic傳入的內容,55 } fmt.Println("d") }() f() } func f(){ fmt.Println("a") panic(55) fmt.Println("b") fmt.Println("f") }
輸出結果:
a
c
55
d
exit code 0, process exited normally.
defer
defer 英文原意: vi. 推遲;延期;服從 vt. 使推遲;使延期。
defer的思想類似于C++中的析構函數,不過Go語言中“析構”的不是對象,而是函數,defer就是用來添加函數結束時執行的語句。注意這里強調的是添加,而不是指定,因為不同于C++中的析構函數是靜態的,Go中的defer是動態的。
func f() (result int) { defer func() { result++ }() return 0 }
上面函數返回1,因為defer中添加了一個函數,在函數返回前改變了命名返回值的值。是不是很好用呢。但是,要注意的是,如果我們的defer語句沒有執行,那么defer的函數就不會添加,如果把上面的程序改成這樣:
func f() (result int) { return 0 defer func() { result++ }() return 0 }
上面的函數就返回0了,因為還沒來得及添加defer的東西,函數就返回了。
另外值得一提的是,defer可以多次,這樣形成一個defer棧,后defer的語句在函數返回時將先被調用。
recover
recover 英文原意: vt. 恢復;彌補;重新獲得 vi. 恢復;勝訴;重新得球 n. 還原至預備姿勢
上面說到,panic的函數并不會立刻返回,而是先defer,再返回。這時候(defer的時候),如果有辦法將panic捕獲到,并阻止panic傳遞,那就異常的處理機制就完善了。
Go語言提供了recover內置函數,前面提到,一旦panic,邏輯就會走到defer那,那我們就在defer那等著,調用recover函數將會捕獲到當前的panic(如果有的話),被捕獲到的panic就不會向上傳遞了,于是,世界恢復了和平。你可以干你想干的事情了。
不過要注意的是,recover之后,邏輯并不會恢復到panic那個點去,函數還是會在defer之后返回。
panic
panic 英文原意:n. 恐慌,驚慌;大恐慌 adj. 恐慌的;沒有理由的 vt. 使恐慌 vi. 十分驚慌
panic 是用來表示非常嚴重的不可恢復的錯誤的。在Go語言中這是一個內置函數,接收一個interface{}類型的值(也就是任何值了)作為參數。panic的作用就像我們平常接觸的異常。不過Go可沒有try…catch,所以,panic一般會導致程序掛掉(除非recover)。所以,Go語言中的異常,那真的是異常了。你可以試試,調用panic看看,程序立馬掛掉,然后Go運行時會打印出調用棧。
但是,關鍵的一點是,即使函數執行的時候panic了,函數不往下走了,運行時并不是立刻向上傳遞panic,而是到defer那,等defer的東西都跑完了,panic再向上傳遞。所以這時候 defer 有點類似 try-catch-finally 中的 finally。
panic就是這么簡單。拋出個真正意義上的異常。
結論:
Go對待異常(準確的說是panic)的態度就是這樣,沒有全面否定異常的存在,同時極力不鼓勵多用異常。
關于golang中異常處理的使用場景就分享到這里了,希望以上內容可以對大家有一定的幫助,可以學到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。