繁体   English   中英

Clojure:从ArrayMap转换为HashMap

[英]Clojure: Conversion from ArrayMap to HashMap

我正在研究clojure源代码。 PersistentArrayMap的实现在assoc函数中具有以下条件:

    if(array.length >= HASHTABLE_THRESHOLD)
        return createHT(array).assoc(key, val);

其中HASHTABLE_THRESHOLD为16.如果数组映射已有8对,则assoc应返回PersistentHashMap 现在看看这个clojure代码:

(defn create [n, init] (if (= n 0) init (recur (dec n) (assoc init n n))))
(type (create 9 {}))

输出是clojure.lang.PersistentArrayMap ,它不应该是PersistentHashMap吗? 如果我用10而不是9,那就是我得到的。

这是在Clojure 1.10中修复的assoc的错误: https//dev.clojure.org/jira/browse/CLJ-1587 此提交 (更不用说提交是4年了)。

该bug只影响了assoc ,因此生成9键映射的其他一些方法不受影响:

Clojure 1.9.0
(type {9 9, 8 8, 7 7, 6 6, 5 5, 4 4, 3 3, 2 2, 1 1})
=> clojure.lang.PersistentHashMap
(type (into {} (map vector (range 9) (range 9))))
=> clojure.lang.PersistentHashMap

修复后:

Clojure 1.10.0-beta4
(type (create 9 {}))
=> clojure.lang.PersistentHashMap

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM