_由claj_发表的评论
对当前rand(clojure 1.6.0)的基准测试,$ java -version
java版本 "1.7.0_51"
OpenJDK运行环境(IcedTea 2.4.4)(7u51-2.4.4-0ubuntu0.13.10.1)
OpenJDK 64位服务器VM(构建24.45-b08,混合模式)
:jvm-opts ^:replace [](即不向JVM传递参数)
(bench (rand 10))
评估次数:1281673680,在21361228次调用的60个样本中。
平均执行时间:43.630075纳秒
执行时间标准差:0.420801纳秒
执行时间下四分位数:42.823363纳秒(2.5%)
执行时间上四分位数:44.456267纳秒(97.5%)
使用的开销:3.194591纳秒
在60个样本中找到1个异常值(1.6667%)
轻度严重 1(1.6667%)
异常值所带来的方差:1.6389% 异常值使得方差略微膨胀
Clojure 1.7.0-master-SNAPSHOT.
(bench (rand 10))
评估次数:26,226,948,60次,在60个样本,437,115,181次调用中。
执行时间平均值:20.474605纳秒
执行时间标准偏差:0.248034纳秒
执行时间下四分位数:20.129894纳秒(2.5%)
执行时间上四分位数:21.009303纳秒(97.5%)
额外消耗:2.827337纳秒
在60个样本中找到2个异常值(3.3333%)
轻度严重 2(3.3333%)
异常值所带来的方差:1.6389% 异常值使得方差略微膨胀
在Clojure 1.6.0上我得到了类似的结果,并进行了几次不同测试,结果都相似。java.util.Random.nextInt表现得相当糟糕。ThreadLocalRandom版本的.nextInt表现更好,但rand-int可以接受负整数,这会导致对(rand-int n)的一些转换,因为它需要上界和下界而不是简单的随机数[0,1)的乘积。
修改
(.nextDouble (ThreadLocalRandom/current) 参数)处理得非常快,但不能处理负参数。普通乘法给出的速度大约是30纳秒。