Golang中的錯誤處理深入分析
一、Go的內(nèi)建類型error
error類型其實是一個接口類型,也是GO語言的內(nèi)建類型;
在這個接口類型的聲明中只包含了一個方法Error;
Error方法不接受任何參數(shù),但是會返回一個string類型的結(jié)果。
可以通過errors.New(string) error 方法聲明一個error類型的變量;
通過模塊化的方式生成錯誤信息,可以使用fmt.Errorf 。
這個方法相當于先調(diào)用fmt.Sprintf得到確切的錯誤信息,再調(diào)用errors.New函數(shù),得到包含錯誤信息的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)
}
}二、怎么判斷一個錯誤值具體代表那一類錯誤
- 對于類型在已知范圍內(nèi)的一系列錯誤,一般使用類型斷言表達式或類型switch語句來判斷;
- 對于已有相應變量且類型相同的一系列錯誤,一般直接使用判等操作來判斷;
- 對于沒有相應變量且類型未知的一系列錯誤值,只能使用其錯誤信息的字符串表示形式來判斷;
知道錯誤類型的所屬范圍
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
}
}
知道錯誤變量是哪幾個值
func knownError(err error) {
switch err {
case os.ErrClosed:
fmt.Println("errClosed")
case os.ErrInvalid:
fmt.Println("errInvalid")
case os.ErrPermission:
fmt.Println("errPermission")
}
}
三、錯誤值體系的兩種方法
立體的-錯誤類型體系
用類型建立起樹形結(jié)構(gòu)的錯誤體系,用統(tǒng)一字段建立起可追根溯源的鏈式錯誤關(guān)系。
- 將error作為嵌入接口。
- 使用名為Err、類型為error接口類型的字段,代表當前錯誤的潛在錯誤。錯誤類型的值之間的另外一種關(guān)系:鏈式關(guān)系。
扁平的-錯誤值列表
通過errors.New函數(shù)生成錯誤值,預先創(chuàng)建一些代表已知錯誤的錯誤值。
隱患:通過errors.New函數(shù)生成的錯誤值只能被賦給變量,而不能賦給常量。又因為這些變量需要給包外代碼使用,所以只能是公開的。這樣帶來的問題:惡意代碼修改了變量的值,相應的判等操作的結(jié)果也會隨之改變。
解決方案一:私有化變量,也就是說讓首字母小寫,然后編寫公開的用于獲取錯誤值以及用于判等錯誤值的函數(shù)。
解決方案二:此方案存在于syscall包中,使用其中一個叫Errno的類型,該類型代表了系統(tǒng)調(diào)用時可能發(fā)生的底層錯誤。這個錯誤類型是error接口的實現(xiàn)類型,同時也是對內(nèi)建類型uintptr的再定義類型。由于uintptr可以作為常量類型,所以syscall.Erron也可以作為錯誤的常量類型??梢苑抡者@種方式來構(gòu)建我們自己的錯誤值列表。
到此這篇關(guān)于Golang中的錯誤處理深入分析的文章就介紹到這了,更多相關(guān)Go錯誤處理內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Go語言中切片(slice)和數(shù)組(array)的區(qū)別詳解
Go語言中切片(slice)和數(shù)組(array)是兩種不同的數(shù)據(jù)結(jié)構(gòu),它們在用法和行為上有一些重要區(qū)別,所以本文就通過一些代碼示例給大家詳細的介紹一下Go語言中切片(slice)和數(shù)組(array)的區(qū)別,需要的朋友可以參考下2023-09-09
Go中g(shù)routine通信與context控制實例詳解
隨著context包的引入,標準庫中很多接口因此加上了context參數(shù),下面這篇文章主要給大家介紹了關(guān)于Go中g(shù)routine通信與context控制的相關(guān)資料,需要的朋友可以參考下2022-02-02

