问题由 Lee Spector 在邮件列表中报告
https://groups.google.com/d/msg/clojure/8TL7IGmE7N0/u1xfgTOLDRgJ
以下是 Lee 文章中描述问题的引用
`
以下是一个示例,通过 next 步骤逐步走过 '(() 0),并打印每个步骤的节点
(loop [z (zip/seq-zip '(() 0))]
(if (zip/end? z)
:done
(do (println (zip/node z))
(recur (zip/next z)))))
That produces
(() 0)
()
nil
0
:done
我不期望那里有 nil。
`
根本原因是 {{seq-zip}} 将 {{identity}} 作为 {{children}} 参数传递给 {{zipper}}。应用于 {{()}}, 这返回 {{()}}, 这是一个真值,导致 {{zipper}} 进入一个不存在的子树。
一个自然的解决方案就是用 {{seq}} 替换 {{identity}}
`
(defn seq-zip [root]
(zipper seq?
seq ;; changed
(fn [node children] (with-meta children (meta node)))
root))
`
这个改变之后,上面的例子中没有产生 {{nil}}。相关补丁将随后发布。