Golang中的錯(cuò)誤處理深入分析
一、Go的內(nèi)建類型error
error類型其實(shí)是一個(gè)接口類型,也是GO語言的內(nèi)建類型;
在這個(gè)接口類型的聲明中只包含了一個(gè)方法Error;
Error方法不接受任何參數(shù),但是會(huì)返回一個(gè)string類型的結(jié)果。
可以通過errors.New(string) error
方法聲明一個(gè)error類型的變量;
通過模塊化的方式生成錯(cuò)誤信息,可以使用fmt.Errorf
。
這個(gè)方法相當(dāng)于先調(diào)用fmt.Sprintf
得到確切的錯(cuò)誤信息,再調(diào)用errors.New
函數(shù),得到包含錯(cuò)誤信息的error類型值。最后返回該值。
使用error的案例:
package main import ( "errors" "fmt" ) func echo(request string) (response string, err error) { if request == "" { err = errors.New("empty request") return } response = fmt.Sprintf("echo: %s", request) return } func main() { for _, request := range []string{"", "hello!"} { fmt.Printf("request: %s\n", request) resp, err := echo(request) if err != nil { fmt.Printf("error: %s\n", err) continue } fmt.Printf("response: %s \n", resp) } }
二、怎么判斷一個(gè)錯(cuò)誤值具體代表那一類錯(cuò)誤
- 對于類型在已知范圍內(nèi)的一系列錯(cuò)誤,一般使用類型斷言表達(dá)式或類型switch語句來判斷;
- 對于已有相應(yīng)變量且類型相同的一系列錯(cuò)誤,一般直接使用判等操作來判斷;
- 對于沒有相應(yīng)變量且類型未知的一系列錯(cuò)誤值,只能使用其錯(cuò)誤信息的字符串表示形式來判斷;
知道錯(cuò)誤類型的所屬范圍
import ( "os" "os/exec" ) func underlyingError(err error) error { switch errtype := err.(type) { case *os.PathError: return errtype.Err case *os.LinkError: return errtype.Err case *os.SyscallError: return errtype.Err case *exec.Error: return errtype.Err default: return err } }
知道錯(cuò)誤變量是哪幾個(gè)值
func knownError(err error) { switch err { case os.ErrClosed: fmt.Println("errClosed") case os.ErrInvalid: fmt.Println("errInvalid") case os.ErrPermission: fmt.Println("errPermission") } }
三、錯(cuò)誤值體系的兩種方法
立體的-錯(cuò)誤類型體系
用類型建立起樹形結(jié)構(gòu)的錯(cuò)誤體系,用統(tǒng)一字段建立起可追根溯源的鏈?zhǔn)藉e(cuò)誤關(guān)系。
- 將error作為嵌入接口。
- 使用名為Err、類型為error接口類型的字段,代表當(dāng)前錯(cuò)誤的潛在錯(cuò)誤。錯(cuò)誤類型的值之間的另外一種關(guān)系:鏈?zhǔn)疥P(guān)系。
扁平的-錯(cuò)誤值列表
通過errors.New
函數(shù)生成錯(cuò)誤值,預(yù)先創(chuàng)建一些代表已知錯(cuò)誤的錯(cuò)誤值。
隱患:通過errors.New
函數(shù)生成的錯(cuò)誤值只能被賦給變量,而不能賦給常量。又因?yàn)檫@些變量需要給包外代碼使用,所以只能是公開的。這樣帶來的問題:惡意代碼修改了變量的值,相應(yīng)的判等操作的結(jié)果也會(huì)隨之改變。
解決方案一:私有化變量,也就是說讓首字母小寫,然后編寫公開的用于獲取錯(cuò)誤值以及用于判等錯(cuò)誤值的函數(shù)。
解決方案二:此方案存在于syscall包中,使用其中一個(gè)叫Errno的類型,該類型代表了系統(tǒng)調(diào)用時(shí)可能發(fā)生的底層錯(cuò)誤。這個(gè)錯(cuò)誤類型是error接口的實(shí)現(xiàn)類型,同時(shí)也是對內(nèi)建類型uintptr的再定義類型。由于uintptr可以作為常量類型,所以syscall.Erron
也可以作為錯(cuò)誤的常量類型??梢苑抡者@種方式來構(gòu)建我們自己的錯(cuò)誤值列表。
到此這篇關(guān)于Golang中的錯(cuò)誤處理深入分析的文章就介紹到這了,更多相關(guān)Go錯(cuò)誤處理內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
- 詳解golang函數(shù)多返回值錯(cuò)誤處理與error類型
- Go語言中的錯(cuò)誤處理最佳實(shí)踐詳解
- 重學(xué)Go語言之錯(cuò)誤處理與異常機(jī)制詳解
- Go語言中錯(cuò)誤處理的方式總結(jié)
- Go語言中實(shí)現(xiàn)完美錯(cuò)誤處理實(shí)踐分享
- Golang錯(cuò)誤處理方式異常與error
- Golang中的錯(cuò)誤處理的示例詳解
- Golang中的錯(cuò)誤處理的示例詳解
- Go 代碼規(guī)范錯(cuò)誤處理示例經(jīng)驗(yàn)總結(jié)
- Go?錯(cuò)誤處理實(shí)踐總結(jié)示例
- Go錯(cuò)誤處理的幾種方式
相關(guān)文章
Go語言實(shí)現(xiàn)Snowflake雪花算法
雪花算法產(chǎn)生的背景當(dāng)然是twitter高并發(fā)環(huán)境下對唯一ID生成的需求,得益于twitter內(nèi)部牛的技術(shù),雪花算法能夠流傳于至今并且被廣泛使用,本文就詳細(xì)的介紹一下,感興趣的可以了解一下2021-06-06golang利用unsafe操作未導(dǎo)出變量-Pointer使用詳解
這篇文章主要給大家介紹了關(guān)于golang利用unsafe操作未導(dǎo)出變量-Pointer使用的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),需要的朋友可以參考借鑒,下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2018-08-08Go+Kafka實(shí)現(xiàn)延遲消息的實(shí)現(xiàn)示例
本文主要介紹了Go+Kafka實(shí)現(xiàn)延遲消息的實(shí)現(xiàn)示例,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2022-07-07Golang記錄、計(jì)算函數(shù)執(zhí)行耗時(shí)、運(yùn)行時(shí)間的一個(gè)簡單方法
這篇文章主要介紹了Golang記錄、計(jì)算函數(shù)執(zhí)行耗時(shí)、運(yùn)行時(shí)間的一個(gè)簡單方法,本文直接給出代碼實(shí)例,需要的朋友可以參考下2015-07-07Go語言中println和fmt.Println區(qū)別
本文主要介紹了Go語言中println和fmt.Println區(qū)別,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2023-07-07