如何使用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.SyntaxError从Decode. 正如你所注意到的,这永远不会是真的。
您想要做的有点不同:检查是否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)
}
}