有没有一种通用的方法来使用 transit (反)序列化数组?
我遇到了这样的情况
(require '[cognitect.transit :as transit])
(def array-write-handler (transit/write-handler "pod.babashka.sql/array" vec))
(def array-type (class (into-array Object [])))
(defn write-transit [v]
(let [baos (java.io.ByteArrayOutputStream.)]
(transit/write (transit/writer baos :json {:handlers {array-type array-write-handler}}) v)
(.toString baos "utf-8")))
(prn (write-transit (into-array Object ["foo"]))) ;; works
(prn (write-transit (into-array String ["foo"]))) ;; ERROR
看起来你不得不为每种类型显式进行序列化编码,这可能导致错误且繁琐。在 transit 决定无法序列化某种类型的对象之前,我能使用某种类型的后备处理程序吗?在这个后备处理中,我可以检查对象是否为数组,使用 .isArray?
我目前的工作方式是使用 walk/postwalk 创建一些自定义表示,但这似乎违背了 transit 的初衷。