这发生在 has-set 宏和 hash-set 文本字面量中。这是我从 repl 中得到的
cljs.user=> (hash-set 1 '1 2 '2 3 '3 4 '4 5)
`
cljs.user=> (hash-set 1 '1 2 '2 3 '3 4 '4)
{1 2 3 4 5}
cljs.user=> #{ 1 '1 2 '2 3 '3 4 '4}
{1 1 2 2 3 3 4 4}
cljs.user=> #{ 1 '1 2 '2 3 '3 4 '4 5}
{2 1 4 4 3 2 1 3}
cljs.user=> #{ 1 '1 2 '2 3 '3 4 '4 5 '5}
{2 1 4 4 3 2 5 1 3}
cljs.user=> (apply hash-set [1 '1 2 '2 3 '3 4 '4])
{2 5 1 4 4 3 2 5 1 3}
将 hash-set 作为函数调用会给出正确的结果。hash-set 宏在元素超过 8 个之前提供错误的结果,并且使用 PersistentHashSet 的 fromArray 方法而不是为集合创建字面量 PersistentArrayMap。
{1 2 3 4}
`
字面量表示法无论如何都会有错误。