Golang中使用errors返回調(diào)用堆棧信息
Golang的errors包返回堆棧信息
標準庫errors提供了處理錯誤的方法。比如常用的func New(text string) error
用該方法處理錯誤信息,就只會輸出自定義的 text 到控制臺或者日志文件,
沒有其它輔助排查的信息輸出,所以常規(guī)我們就只能根據(jù) text 去全局搜哪里拋出了這個錯誤,再來定位代碼層面上下文問題。
當然,不是不行,但是嵌套代碼多,拋出 text 存在多處一致的情況,就比較麻煩了。比如以下例子:
package main import ( "errors" "fmt" "os" ) func err1() error { return errors.New("報錯啦,拋出異常??!") } func err2() error { return errors.New("報錯啦,拋出異常!!") } func err3() error { return errors.New("報錯啦,拋出異常??!") } func main() { err := err1() if err != nil { fmt.Println(err) os.Exit(0) } err = err2() if err != nil { fmt.Println(err) os.Exit(0) } err = err3() if err != nil { fmt.Println(err) os.Exit(0) } }
運行結(jié)果:
報錯啦,拋出異常?。?/p>
代碼中有三處同樣的錯誤輸出,根據(jù)這個錯誤信息,無法判斷是來源于哪個方法,只能通過調(diào)試或者在每個 err!=nil 內(nèi)再加輸出進行定位。
這里就可以用第三方的開源庫:github.com/go-errors/errors
下面用 github.com/go-errors/errors改造下
package main import ( "fmt" "github.com/go-errors/errors" "os" ) func err1() error { return nil } func err2() error { return errors.New("報錯啦,拋出異常??!") } func err3() error { return errors.New("報錯啦,拋出異常?。?) } func main() { err := err1() if err != nil { fmt.Println(err.(*errors.Error).ErrorStack()) os.Exit(0) } err = err2() if err != nil { fmt.Println(err.(*errors.Error).ErrorStack()) os.Exit(0) } err = err3() if err != nil { fmt.Println(err.(*errors.Error).ErrorStack()) os.Exit(0) } }
運行結(jié)果:
*errors.Error 報錯啦,拋出異常?。?
D:/gotest/src/test/main.go:14 (0x49756b)
main: return errors.New("報錯啦,拋出異常?。?quot;)
D:/gotest/src/test/main.go:27 (0x497559)
main: err = err2()
D:/golang/src/runtime/proc.go:250 (0x4379fe)
main: fn()
D:/golang/src/runtime/asm_amd64.s:1594 (0x45ee41)
goexit: BYTE $0x90 // NOP
有了調(diào)用堆棧信息,就很明確知道 err2()存在問題。這個庫會記錄調(diào)用棧,通過ErrorStack方法返回調(diào)用棧信息
以上就是Golang中使用errors返回調(diào)用堆棧信息的詳細內(nèi)容,更多關(guān)于Golang errors返回堆棧信息的資料請關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
聊聊go xorm生成mysql的結(jié)構(gòu)體問題
這篇文章主要介紹了go xorm生成mysql的結(jié)構(gòu)體問題,本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友參考下吧2022-03-03Go語言中基本數(shù)據(jù)類型的相互轉(zhuǎn)換詳解
Go在不同類型的變量之間賦值時需要顯示轉(zhuǎn)換,不能自動轉(zhuǎn)換。這篇文章主要和大家介紹了Go語言中基本數(shù)據(jù)類型的相互轉(zhuǎn)換,感興趣的小伙伴可以了解一下2022-10-10