關於golang中的錯誤處理機制的詳細介紹
基礎
錯誤處理應該是工程的一部分,Golang中的error是一個interface
類型,如下:
type error interface { Error() string }
凡是實作Error()
方法的結構,都可以當作錯誤處理。因此如果函數可能出現錯誤,那麼可以在傳回值的最後,傳回一個錯誤,例如:
func foo() error { // ... do something return errors.New("foo error") }
#直接傳回錯誤
直接傳回錯誤,類似於直接傳回字串類型的錯誤,或錯誤碼之類的。字串類型的錯誤,在基礎部分提到了。錯誤碼相當於Linux、C程式中的錯誤碼,一般我們需要自己定義。舉個例子:
package mypkg type ErrCode int const ( ERR1 = 1 ERR2 = 2 ERR3 = 3 ) func sub(a, b int) (int, ErrCode) { if b < 0 { return 0, ERR1 } else if a < b { return 0, Err2 } else if a < 0 { return 0, Err3 } return a - b }
這種類型的錯誤,編寫簡單,但是有兩個缺陷:
1、外層如果想要使用錯誤碼,則需要引入這個包,容易出現循環引用的情況。
2、如果套件內部修改回傳的錯誤碼類型,則外部使用到錯誤碼的地方,都要進行對應的修改,破壞了封閉性。
對於第一個缺陷,可以使用一個第三方的包,專門存放錯誤碼,這個方式值得商榷。永遠不要透過判斷Error()方法傳回的字串的值,來進行對應的錯誤處理! ! !
傳回自訂類型的錯誤
該方式可以傳回自訂的類型,並透過斷言自訂類型,來進行相關的錯誤處理;自訂類型可以攜帶更多的信息,程式碼實例:
package main import ( "errors" "fmt" "runtime/debug" ) type MyError struct { Inner error // 内粗错误 Message string // 自定义错误信息 StackTrace string // 堆栈信息 Misc map[string]interface{} //其它的一些数据 } func (myError MyError) Error() string { return myError.Message } func wrapError(err error, msg string, msgArgs ...interface{}) MyError { return MyError{ Inner: err, Message: fmt.Sprintf(msg, msgArgs), StackTrace: string(debug.Stack()), Misc: make(map[string]interface{}), } } func Handle(key int) error { if key < 0 { return wrapError(errors.New("key < 0"), "This is an error test") } return nil } func main() { if err := Handle(-1); err != nil { if e, ok := err.(MyError); ok { fmt.Printf("Inner: %v, Message: %v, StackTrace: %v\n", e.Inner, e.Message, e.StackTrace) // 这里输出对应的数据 } } }
這種方式處理問題更加方便,但是仍然可能會有包循環引用的問題。
隱藏內部細節的錯誤處理
上述兩種方式,可以適應一些場景,不過都無法解決可能存在循環依賴的問題。為此,我們使用github.com/pkg/errors
的套件來解決問題,給出一個程式碼實例。
func New(message string) error
如果有現成的error,我們需要對他進行再次包裝處理,這時候有三個函數可以選擇。
//只附加新的信息 func WithMessage(err error, message string) error //只附加调用堆栈信息 func WithStack(err error) error //同时附加堆栈和信息 func Wrap(err error, message string) error
其實上面的包裝,很類似Java的異常包裝,被包裝的error,其實就是Cause,在前面的章節提到錯誤的根本原因,就是這個Cause。所以這個錯誤處理函式庫為我們提供了Cause函數讓我們可以得到最根本的錯誤原因。
func Cause(err error) error { type causer interface { Cause() error } for err != nil { cause, ok := err.(causer) if !ok { break } err = cause.Cause() } return err }
使用for迴圈一直找到最根本(最底層)的那個error。
相關文章教學推薦:golang教學
#以上是關於golang中的錯誤處理機制的詳細介紹的詳細內容。更多資訊請關注PHP中文網其他相關文章!

熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

Video Face Swap
使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

記事本++7.3.1
好用且免費的程式碼編輯器

SublimeText3漢化版
中文版,非常好用

禪工作室 13.0.1
強大的PHP整合開發環境

Dreamweaver CS6
視覺化網頁開發工具

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)

在Go中安全地讀取和寫入檔案至關重要。指南包括:檢查檔案權限使用defer關閉檔案驗證檔案路徑使用上下文逾時遵循這些準則可確保資料的安全性和應用程式的健全性。

如何為Go資料庫連線配置連線池?使用database/sql包中的DB類型建立資料庫連線;設定MaxOpenConns以控制最大並發連線數;設定MaxIdleConns以設定最大空閒連線數;設定ConnMaxLifetime以控制連線的最大生命週期。

可以透過使用gjson函式庫或json.Unmarshal函數將JSON資料儲存到MySQL資料庫中。 gjson函式庫提供了方便的方法來解析JSON字段,而json.Unmarshal函數需要一個目標類型指標來解組JSON資料。這兩種方法都需要準備SQL語句和執行插入操作來將資料持久化到資料庫中。

GoLang框架與Go框架的差異體現在內部架構與外部特性。 GoLang框架基於Go標準函式庫,擴充其功能,而Go框架由獨立函式庫組成,以實現特定目的。 GoLang框架更靈活,Go框架更容易上手。 GoLang框架在效能上稍有優勢,Go框架的可擴充性更高。案例:gin-gonic(Go框架)用於建立RESTAPI,而Echo(GoLang框架)用於建立Web應用程式。

後端學習路徑:從前端轉型到後端的探索之旅作為一名從前端開發轉型的後端初學者,你已經有了nodejs的基礎,...

FindStringSubmatch函數可找出正規表示式匹配的第一個子字串:此函數傳回包含匹配子字串的切片,第一個元素為整個匹配字串,後續元素為各個子字串。程式碼範例:regexp.FindStringSubmatch(text,pattern)傳回符合子字串的切片。實戰案例:可用於匹配電子郵件地址中的域名,例如:email:="user@example.com",pattern:=@([^\s]+)$獲取域名match[1]。

Go框架開發常見問題:框架選擇:取決於應用需求和開發者偏好,如Gin(API)、Echo(可擴展)、Beego(ORM)、Iris(效能)。安裝和使用:使用gomod指令安裝,導入框架並使用。資料庫互動:使用ORM庫,如gorm,建立資料庫連線和操作。身份驗證和授權:使用會話管理和身份驗證中間件,如gin-contrib/sessions。實戰案例:使用Gin框架建立一個簡單的部落格API,提供POST、GET等功能。

Go語言中使用預先定義時區包含下列步驟:匯入"time"套件。透過LoadLocation函數載入特定時區。在建立Time物件、解析時間字串等操作中使用已載入的時區,進行日期和時間轉換。使用不同時區的日期進行比較,以說明預先定義時區功能的應用。
