我希望在项目中自定义一个error. 参考了 [链接](https://studygolang.com/articles/12045) 然后设计了自己的error.
我希望将自定义的error以json string的形式输入到日志上. 所以重写了`Error()` 方法.
问题点: 如果自定义Error的Err没有输出, 请问问题点在哪里呢?
```go
package main
import (
"encoding/json"
"errors"
"fmt"
)
type Error struct {
Op string
Kind int
Err error
}
func (e Error) Error() string {
b, _ := json.Marshal(&e)
return string(b[:])
}
func main() {
err := Error{
Op: "main",
Kind: 1,
Err: Error{
Op: "sub",
Kind: 2,
Err: errors.New("message"),
},
}
fmt.Println(err)
}
// 输出
// {"Op":"main","Kind":1,"Err":{"Op":"sub","Kind":2,"Err":{}}}
```
有疑问加站长微信联系(非本文作者)