GO語言中err接口及defer延遲異常處理分析
err接口
Go語言引入了一個關(guān)于錯誤處理的標(biāo)準(zhǔn)模式,即error接口,它是Go語言內(nèi)建的接口類型,該接口的定義如下:
type error interface {
Error() string
}
調(diào)用對應(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時
package main
import (
"errors"
"fmt"
)
func main() {
//接收錯誤信息和正確信息
result,err := test(5,0)
//加了判斷,如果沒有錯誤err=nil
if err!=nil{
fmt.Println(err)
}else {
fmt.Println(result)
}
}
//b為0時拋出異常
func test(a,b int) (result int, err error) { //返回錯誤信息
err = nil
if b==0{
err =errors.New("b不能為0")
}else {
result = a/b
}
return
}
panic函數(shù)
error返回的是一般性的錯誤,但是panic函數(shù)返回的是讓程序崩潰的錯誤。
一般而言,當(dāng)panic異常發(fā)生時,程序會中斷運行。
所以,我們在實際的開發(fā)過程中并不會直接調(diào)用panic( )函數(shù),但是當(dāng)我們編程的程序遇到致命錯誤時,系統(tǒng)會自動調(diào)用該函數(shù)來終止整個程序的運行,也就是系統(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?于延遲一個函數(shù)的執(zhí)行,調(diào)用了,但是沒有執(zhí)行,也會完成參數(shù)的傳遞
defer fmt.Println("333")
defer fmt.Println("222")
defer fmt.Println("111")
依次輸出順序:111,222,333
如果一個函數(shù)中有多個defer語句,它們會以后進(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防止程序中斷
運行時panic異常一旦被引發(fā)就會導(dǎo)致程序崩潰。這當(dāng)然不是我們愿意看到的,因為誰也不能保證程序不會發(fā)生任何運行時錯誤。
Go語言為我們提供了專用于“攔截”運行時panic的內(nèi)建函數(shù)——recover。它可以是當(dāng)前的程序從運行時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延遲異常的資料請關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
Go 代碼規(guī)范錯誤處理示例經(jīng)驗總結(jié)
這篇文章主要為大家介紹了Go 代碼規(guī)范錯誤處理示例實戰(zhàn)經(jīng)驗總結(jié),有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-08-08
Go語言操作數(shù)據(jù)庫及其常規(guī)操作的示例代碼
這篇文章主要介紹了Go語言操作數(shù)據(jù)庫及其常規(guī)操作的示例代碼,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2021-04-04
深入解析Go語言編程中slice切片結(jié)構(gòu)
這篇文章主要介紹了Go語言編程中slice切片結(jié)構(gòu),其中Append方法的用法介紹較為詳細(xì),需要的朋友可以參考下2015-10-10
gorm整合進(jìn)go-zero的實現(xiàn)方法
go-zero提供的代碼生成器里面,沒有提供orm框架操作,但是提供了遍歷的緩存操作,所以可以利用gorm當(dāng)作一個sql語句的生成器,把生成后的sql語句放到go-zero生成的模板中去執(zhí)行,對gorm整合進(jìn)go-zero的實現(xiàn)方法感興趣的朋友一起看看吧2022-03-03

