当前位置: > > > > 堆栈跟踪和 golang 错误。Unwrap()
来源:stackoverflow
2024-04-29 15:54:37
0浏览
收藏
偷偷努力,悄无声息地变强,然后惊艳所有人!哈哈,小伙伴们又来学习啦~今天我将给大家介绍《堆栈跟踪和 golang 错误。Unwrap()》,这篇文章主要会讲到等等知识点,不知道大家对其都有多少了解,下面我们就一起来看一吧!当然,非常希望大家能多多评论,给出合理的建议,我们一起学习,一起进步!
问题内容
我想构建一个堆栈跟踪,其中包括一个低级数据库错误和第二个人类可读的错误。
golang 1.13 中新的 errors.unwrap()
函数是为此目的而构建的吗?不确定我明白如何使用它。寻找有关如何执行此操作的示例。
// model/book.go package model type Book struct { Id uint32 `json:"id" db:"id"` Title string `json:"title" db:"title"` Author string `json:"author" db:"author"` Price float32 `json:"price" db:"price"` } func (b *Book) Tablename() string { return "books" } // main.go package main func main() { bk := model.Book{ Title: "oliver twist", Author: "charles dickens", Price: 10.99, } err:= Create(&bk) if err !=nil { // how to use Unwrap? } } func Create(book *model.Book) error { insertSQL := "INSERT INTO ...." // code to insert if err != nil { return err } book.Id = uint32(lastID) return nil }
解决方案
errors.unwrap
用于剥离已包装的错误层。
// error 1 wrapped by 2 wrapped by 3 err1 := errors.new("error 1") err2 := fmt.errorf("error 2: %w", err1) err3 := fmt.errorf("error 3: %w", err2) fmt.println(err1) // "error 1" fmt.println(err2) // "error 2: error 1" fmt.println(err3) // "error 3: error 2: error 1" // unwrap peels a layer off fmt.println(errors.unwrap(err3)) // "error 2: error 1" fmt.println(errors.unwrap(errors.unwrap(err3))) // "error 1"
您可以递归地展开以找到最内部的错误:
currenterr := err3 for errors.unwrap(currenterr) != nil { currenterr = errors.unwrap(currenterr) } fmt.println(currenterr) // "error 1"
对于同时包含低级错误和人类可读错误的错误,您可以实现自定义错误。
type error struct { lowlevel error humanreadable string } func (e error) error() string { return e.humanreadable } func (e error) unwrap() error { return e.lowlevel } // helper func newerror(inner error, outer string) *error { return &error{ lowlevel: inner, humanreadable: outer, } }
在您调用的函数中:
func create(book *model.book) error { ... if err != nil { return newerror(err, "failed to create book") } ... }
在你的来电者中:
func main() { ... err := Create(&bk) if err != nil { log.Print(errors.Unwrap(err)) // internally log low-level error fmt.Print(err) // present human-readable error to user } ... }
好了,本文到此结束,带大家了解了《堆栈跟踪和 golang 错误。Unwrap()》,希望本文对你有所帮助!关注公众号,给大家分享更多Golang知识!