运行下面的代码,堆栈跟踪输出,行号为fmt.Print(...)。但是我想输出logError(err). 我想我需要打电话xerrors.Caller(1)去做,但我不知道怎么办。帮我。import ( "fmt" "io/ioutil" "golang.org/x/xerrors")func main() { _, err := ioutil.ReadFile("") if err != nil { logError(err) return }}func logError(err error) { fmt.Printf("%+v", xerrors.Errorf(": %w", err))}
1 回答
暮色呼如
TA贡献1853条经验 获得超9个赞
我想你想要的是:
import (
"fmt"
"io/ioutil"
"golang.org/x/xerrors"
)
func doWhatever() error {
_, err := ioutil.ReadFile("")
if err != nil {
return xerrors.Errorf("failed doing whatever: %w", err)
}
return nil
}
func main() {
err := doWhatever()
if err != nil {
logError(err)
return
}
}
func logError(err error) {
fmt.Printf("%+v", err)
}
- 1 回答
- 0 关注
- 107 浏览
添加回答
举报
0/150
提交
取消