请在2024 Clojure 状态调查中分享您的想法!

欢迎!请查看关于页面以获取更多关于该功能的信息。

0
ClojureScript

附加的补丁简化并加快了RangedIterator。

以下函数用于以下函数进行了基准测试以测试数组迭代:

`
(defn consume-iterator
[v]
(let [iter (-iterator v)]

(loop []
  (when (.hasNext iter)
    (.next iter)
    (recur)))))

`

以下"简单基准测试"设置如下

(simple-benchmark [v (into [] (range N))] (consume-iterator v) I)

其中‘N’和‘I’来自下表中的“向量大小”和“迭代次数”列。

|向量大小|迭代次数|V8 速度(链接:毫秒)(master)|V8 速度(链接:毫秒)(补丁)|JSC 速度(链接:毫秒)(master)|JSC 速度(链接:毫秒)(补丁)|
| :-- | :-- | :-- | :-- | :-- | :-- | :-- |
|1|100,000|15|11|13|7|
|2|100,000|14|10|7|4|
|4|100,000|18|10|9|5|
|8|100,000|27|12|14|6|
|16|100,000|43|17|19|9|
|32|100,000|74|24|37|15|
|100|100,000|217|59|105|45|
|1000|100,000|2008|524|1032|392|
|10,000|100,000|20390|5856|10249|4178|
|100,000|10,000|20334|5324|10324|4387|

使用的JavaScript引擎版本
V8 版本 5.1.281.47
JSC 版本未知

RangedIterator 构造函数 ranged-iterator 也被设置为私有。

7 个答案

0

评论者:dnolen

首先获得一个没有更改构造函数的性能更改补丁。谢谢。

0

评论者:tmulvaney

已重新提交,构造函数不再私有。

0

评论者:dnolen

抱歉没有说清楚。即使我们现在没有使用它们,也请保留 deftype 的字段。我们想要在不改变API的情况下获得性能提升。

0

评论者:tmulvaney

谢谢,说得有道理。已在本次补丁中修复。

0

评论者:mfikes

将 CLJS-1866-updated.patch 添加到 Patch Tender (i)

0

评论者:mfikes

CLJS-1866-updated.patch 通过 CI 和 Canary

0
参考:[https://clojure.atlassian.net/browse/CLJS-1866](https://clojure.atlassian.net/browse/CLJS-1866)(由 tmulvaney 报告)
...