如何使用errors.Is检测json.SyntaxError

在检查从失败的decoder.Decode 操作返回的错误时,我无法检测到 json.SyntaxError!

在这里,您可以在操场上看到一个工作示例。

正如您所看到的,调试器向我确认它是一个指向 json.SyntaxError 的指针,但 errors.Is 无法检测到它。

我检查了错误。是实现:

func Is(err, target error) bool {
    if target == nil {
        return err == target
    }

    isComparable := reflectlite.TypeOf(target).Comparable()
    for {
        if isComparable && err == target {
            return true
        }
        if x, ok := err.(interface{ Is(error) bool }); ok && x.Is(target) {
            return true
        }
        // TODO: consider supporting target.Is(err). This would allow
        // user-definable predicates, but also may allow for coping with sloppy
        // APIs, thereby making it easier to get away with them.
        if err = Unwrap(err); err == nil {
            return false
        }
    }
}

并且它们是可比较的(isComparable 变量为真)但是,当我希望它继续执行时它会返回真if isComparable && err == target {......

我究竟做错了什么?提前致谢。

回答

当前发生的事情是将 new 的内存地址与json.SyntaxErrorDecode. 正如你所注意到的,这永远不会是真的。

您想要做的有点不同:检查是否err属于类型SyntaxError,然后直接使用该对象。这可以使用type assertions,它基本上检查接口的基础类型(error在这种情况下)是否是更具体的类型。

这就是错误。就像那样。它填充您指定的特定错误类型。使用这种方法,可以看到以下代码:

if err != nil {
    var serr *json.SyntaxError
    
    if errors.As(err, &serr) {
        fmt.Println("Syntax error:", serr)
        fmt.Println("Offset:", serr.Offset)
    } else {
        fmt.Println("Other error:", err)
    }
}


以上是如何使用errors.Is检测json.SyntaxError的全部内容。
THE END
分享
二维码
< <上一篇
下一篇>>