我已经定义了一个 Trie 数据结构的 go struct。type Node struct {Val runeIsWord boolIsRoot boolParent *NodeChildren map[rune]*Node}type Trie struct {Root *Node}trie := algorithms.InitTrie()但是,它会引发错误runtime: goroutine stack exceeds 1000000000-byte limitfatal error: stack overflowruntime stack:runtime.throw(0x10e9426, 0xe)/usr/local/go/src/runtime/panic.go:605 +0x95runtime.newstack(0x0)/usr/local/go/src/runtime/stack.go:1050 +0x6e1runtime.morestack()/usr/local/go/src/runtime/asm_amd64.s:415 +0x86当我插入一些单词并将其保存到 json 文件中时。fmt.Println(json.Marshal(&trie))
1 回答
Helenr
TA贡献1780条经验 获得超3个赞
问题是每个人Node
都引用了它的父母,以及它的孩子。因此,当它对一个孩子进行编码时,对于父字段,它会再次对父字段进行编码,对于该父字段,它会再次对子字段进行编码,等等。一个简单的解决方案是在编码时不使用该Parent
字段
Parent *Node `json:"-"`
这将阻止循环。
https://play.golang.org/p/BdVgMNjlZOa
- 1 回答
- 0 关注
- 204 浏览
添加回答
举报
0/150
提交
取消