有没有一种通用的方法来使用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的目的。