为了账号安全,请及时绑定邮箱和手机立即绑定

UnmarshalJSON 导致堆栈溢出

UnmarshalJSON 导致堆栈溢出

Go
慕虎7371278 2021-12-07 10:57:30
这有效:http : //play.golang.org/p/-Kv3xAguDR。这会导致堆栈溢出:http : //play.golang.org/p/1-AsHFj51O。我不明白为什么。JSONUnmarshaler在这种情况下使用接口的正确方法是什么?package mainimport (    //"bytes"    "encoding/json"    "fmt"    "strings")type T interface {    Printer()}type A struct{ JA string }func (t A) Printer() { fmt.Print("A") }/*func (t *A) UnmarshalJSON(data []byte) error {    i := A{}    dec := json.NewDecoder(bytes.NewReader(data))    if err := dec.Decode(&i); err != nil {        return err    }    i.Printer()    *t = i    return nil}*/var vI []Tfunc main() {    vI = []T{&A{}}    get()}func get() {    dec := json.NewDecoder(strings.NewReader("[{\"JA\":\"OK\"}]"))    if err := dec.Decode(&vI); err != nil {        fmt.Print(err)    }    for _, v := range vI {        v.Printer()    }}
查看完整描述

1 回答

?
偶然的你

TA贡献1841条经验 获得超3个赞

这个


dec.Decode(&i)

将调用 your UnmarshalJSON,而后者又会调用Decode,依此类推。如果你需要解组你的 JSON 然后用它做一些事情,一个巧妙的技术是声明一个本地类型,将你的数据解组到它,然后转换回你想要的类型:


// Type a has no UnmarshalJSON.

type a A

i := a{}

dec := json.NewDecoder(bytes.NewReader(data))

if err := dec.Decode(&i); err != nil {

    return err

}

// Convert back to A.

tt := A(i)

tt.Printer()

*t = tt

// ...

游乐场:http : //play.golang.org/p/HWamV3MbvW。


该类型a没有方法(因此没有堆栈溢出),但可以转换为A.


查看完整回答
反对 回复 2021-12-07
  • 1 回答
  • 0 关注
  • 202 浏览
慕课专栏
更多

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信