运行以下代码,以行号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))
}

最佳答案

我认为您想要的是:

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)
}

10-04 21:32