您好,登錄后才能下訂單哦!
這篇文章主要介紹“Go之panic函數和recover函數使用及捕獲異常的方法是什么”,在日常操作中,相信很多人在Go之panic函數和recover函數使用及捕獲異常的方法是什么問題上存在疑惑,小編查閱了各式資料,整理出簡單好用的操作方法,希望對大家解答”Go之panic函數和recover函數使用及捕獲異常的方法是什么”的疑惑有所幫助!接下來,請跟著小編一起來學習吧!
panic函數是內置的一個函數,他的結構如下:
func panic(v interface{})
此函數接受一個接口類型的值,這個值通常是錯誤的描述,調用次函數后,會引發異常,這將中止當前的程序流程,并在堆棧中記錄當前的異常信息。此函數可以被主動調用,也可以在發生數組越界、空指針引用等情況下被動調用。
我們將上篇文章的除法例子進行小小的修改,使用panic進行錯誤處理:
package main import ( "fmt" ) func divide(a, b int) int{ if b == 0 { panic("division by zero") } return a / b } func main() { result := divide(10, 0) fmt.Println("the result is ",result) }
運行后,程序直接退出了,報division by zero
錯誤。
有些時候,我們不希望panic函數直接粗暴的退出,這時候我們可以使用recover函數對pannic進行捕獲,注意,recover函數只能寫在defer關鍵字之后哦!
recover也是內置函數,他的結構如下:
func recover() interface{}
他能捕獲到的panic函數報出的錯誤,并使用接口類型進行返回。
我們使用recover對例子再次修改,讓程序可以繼續的運行,而不是粗暴的退出,代碼如下:
package main import ( "fmt" ) func divide(a, b int) int{ defer func() { if err:=recover();err!=nil { fmt.Printf("runtime panic : %v\n", err) } }() if b == 0 { panic("division by zero") } return a / b } func main() { result := divide(10, 0) fmt.Println("the result is ",result) }
到此,關于“Go之panic函數和recover函數使用及捕獲異常的方法是什么”的學習就結束了,希望能夠解決大家的疑惑。理論與實踐的搭配能更好的幫助大家學習,快去試試吧!若想繼續學習更多相關知識,請繼續關注億速云網站,小編會繼續努力為大家帶來更多實用的文章!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。