GO語言中err接口及defer延遲異常處理分析
err接口
Go語言引入了一個(gè)關(guān)于錯(cuò)誤處理的標(biāo)準(zhǔn)模式,即error接口,它是Go語言內(nèi)建的接口類型,該接口的定義如下:
type error interface { Error() string }
調(diào)用對(duì)應(yīng)接口
err:=errors.New("this is normal err") fmt.Println(err.Error()) err2:=fmt.Errorf("this is normal err") fmt.Println(err2)
案例:除數(shù)b為0時(shí)
package main import ( "errors" "fmt" ) func main() { //接收錯(cuò)誤信息和正確信息 result,err := test(5,0) //加了判斷,如果沒有錯(cuò)誤err=nil if err!=nil{ fmt.Println(err) }else { fmt.Println(result) } } //b為0時(shí)拋出異常 func test(a,b int) (result int, err error) { //返回錯(cuò)誤信息 err = nil if b==0{ err =errors.New("b不能為0") }else { result = a/b } return }
panic函數(shù)
error返回的是一般性的錯(cuò)誤,但是panic函數(shù)返回的是讓程序崩潰的錯(cuò)誤。
一般而言,當(dāng)panic異常發(fā)生時(shí),程序會(huì)中斷運(yùn)行。
所以,我們?cè)趯?shí)際的開發(fā)過程中并不會(huì)直接調(diào)用panic( )函數(shù),但是當(dāng)我們編程的程序遇到致命錯(cuò)誤時(shí),系統(tǒng)會(huì)自動(dòng)調(diào)用該函數(shù)來終止整個(gè)程序的運(yùn)行,也就是系統(tǒng)內(nèi)置了panic函數(shù)。
案例
package main import "fmt" func main() { test1() test2() test3() } func test1() { fmt.Println("test1") } func test2() { panic("panic test2") //程序中斷 } func test3() { fmt.Println("test3") }
結(jié)果:
test1
panic: panic test2
goroutine 1 [running]:
main.test2(...)
defer延遲
總結(jié)
關(guān)鍵字 defer?于延遲一個(gè)函數(shù)的執(zhí)行,調(diào)用了,但是沒有執(zhí)行,也會(huì)完成參數(shù)的傳遞
defer fmt.Println("333") defer fmt.Println("222") defer fmt.Println("111") 依次輸出順序:111,222,333
如果一個(gè)函數(shù)中有多個(gè)defer語句,它們會(huì)以后進(jìn)先出的順序執(zhí)行。
注意,defer語句只能出現(xiàn)在函數(shù)的內(nèi)部。
defer與匿名函數(shù)結(jié)合使用
案例1:無參數(shù)
package main import "fmt" func main() { a := 10 b := 20 defer func() { fmt.Println("匿名函數(shù)a", a) fmt.Println("匿名函數(shù)b", b) }() a = 100 b = 200 fmt.Println("main函數(shù)a", a) fmt.Println("main函數(shù)b", b) }
結(jié)果:
main函數(shù)a 100
main函數(shù)b 200
匿名函數(shù)a 100
匿名函數(shù)b 200
案例二:有參數(shù)
package main import "fmt" func main() { a := 10 b := 20 //調(diào)用了,也傳參數(shù)了,但是沒有執(zhí)行 defer func(a,b int) { //添加參數(shù) fmt.Println("匿名函數(shù)a", a) fmt.Println("匿名函數(shù)b", b) }(a,b) //傳參數(shù) a = 100 b = 200 fmt.Println("main函數(shù)a", a) fmt.Println("main函數(shù)b", b) }
結(jié)果:
main函數(shù)a 100
main函數(shù)b 200
匿名函數(shù)a 10
匿名函數(shù)b 20
recover防止程序中斷
運(yùn)行時(shí)panic異常一旦被引發(fā)就會(huì)導(dǎo)致程序崩潰。這當(dāng)然不是我們?cè)敢饪吹降模驗(yàn)檎l也不能保證程序不會(huì)發(fā)生任何運(yùn)行時(shí)錯(cuò)誤。
Go語言為我們提供了專用于“攔截”運(yùn)行時(shí)panic的內(nèi)建函數(shù)——recover。它可以是當(dāng)前的程序從運(yùn)行時(shí)panic的狀態(tài)中恢復(fù)并重新獲得流程控制權(quán)。
注意:recover只有在defer調(diào)用的函數(shù)中有效。
func testA() { fmt.Println("testA") } func testB(x int) { //設(shè)置recover() //在defer調(diào)用的函數(shù)中使用recover() defer func() { //防止程序崩潰 //recover() //fmt.Println(recover()) //加了一層判斷 if err:=recover();err!=nil { fmt.Println(err) } }() //匿名函數(shù) var a [3]int a[x] = 999 } func testC() { fmt.Println("testC") } func main() { testA() testB(0) //發(fā)生異常 中斷程序 testC() }
以上就是GO語言中err接口及defer延遲異常處理分析的詳細(xì)內(nèi)容,更多關(guān)于GO語言err接口defer延遲異常的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
golang http 連接超時(shí)和傳輸超時(shí)的例子
今天小編就為大家分享一篇golang http 連接超時(shí)和傳輸超時(shí)的例子,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2019-07-07Golang因Channel未關(guān)閉導(dǎo)致內(nèi)存泄漏的解決方案詳解
這篇文章主要為大家詳細(xì)介紹了當(dāng)Golang因Channel未關(guān)閉導(dǎo)致內(nèi)存泄漏時(shí)蓋如何解決,文中的示例代碼講解詳細(xì),感興趣的小伙伴可以了解一下2023-07-07詳解Go如何優(yōu)雅的對(duì)時(shí)間進(jìn)行格式化
這篇文章主要為大家詳細(xì)介紹了Go語言中是如何優(yōu)雅的對(duì)時(shí)間進(jìn)行格式化的,文中的示例代碼講解詳細(xì),感興趣的小伙伴可以跟隨小編一起了解一下2023-06-06GoFrame框架Scan類型轉(zhuǎn)換實(shí)例
這篇文章主要為大家介紹了GoFrame框架Scan類型轉(zhuǎn)換的實(shí)例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-06-06Go標(biāo)準(zhǔn)庫日志打印及同時(shí)輸出到控制臺(tái)與文件
Go語言內(nèi)置的log包實(shí)現(xiàn)了簡單的日志服務(wù),下面這篇文章主要給大家介紹了關(guān)于Go標(biāo)準(zhǔn)庫日志打印及同時(shí)輸出到控制臺(tái)與文件的相關(guān)資料,文中通過實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下2022-11-11