亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

Golang 使用 Zerolog 并引發錯誤

Golang 使用 Zerolog 并引發錯誤

Go
互換的青春 2023-02-06 18:37:33
我正在使用zerolog在我的 Go 應用程序中進行日志記錄,并且我正在嘗試遵循最佳實踐以僅在堆棧頂部出錯。但是,我不確定如何將兩者都寫入我的錯誤日志并將錯誤向上傳遞:func VeryDeepFunction() (int, error) {   err := doSomethingThatCouldCauseError()   if err != nil {      errMsg := fmt.Sprintf("something bad happened: %+v", err)      log.Error().Msgf(errMsg)      return 0, fmt.Errorf(errMsg)   }   return 1, nil}這對我來說是多余的——格式化字符串,用 zerolog 歸檔,然后再次包裝錯誤。有沒有更正確的方法來做到這一點?
查看完整描述

1 回答

?
HUWWW

TA貢獻1874條經驗 獲得超12個贊

可以鏈接錯誤


package main


import (

    "log"


    "github.com/pkg/errors"

)


var someError = errors.New("something is wrong")


func main() {

    // processing error on top level

    if err := someFunc(); errors.Is(err, someError) {

        log.Println(err)

    }

}


func someFunc() error {

    if err := alwaysError(); err != nil {

        return errors.Wrap(err, "someFunc")

    }


    return nil

}


func alwaysError() error {

    return someError

}

輸出將是


2022/09/01 10:00:46 someFunc: something is wrong

有關詳細信息,請參閱錯誤包


查看完整回答
反對 回復 2023-02-06
  • 1 回答
  • 0 關注
  • 165 瀏覽
慕課專欄
更多

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號