登录
首页 >  Golang >  Go问答

堆栈跟踪和 golang 错误。Unwrap()

来源:stackoverflow

时间:2024-04-29 15:54:37 384浏览 收藏

偷偷努力,悄无声息地变强,然后惊艳所有人!哈哈,小伙伴们又来学习啦~今天我将给大家介绍《堆栈跟踪和 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学习网公众号,给大家分享更多Golang知识!

声明:本文转载于:stackoverflow 如有侵犯,请联系study_golang@163.com删除
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>