gpt4 book ai didi

java - .toArray(new MyClass[0]) 或 .toArray(new MyClass[myList.size()])?

转载 作者:行者123 更新时间:2023-12-01 19:36:44 27 4
gpt4 key购买 nike

假设我有一个 ArrayList

ArrayList<MyClass> myList;

我想调用toArray,是否有性能原因需要使用

MyClass[] arr = myList.toArray(new MyClass[myList.size()]);

超过

MyClass[] arr = myList.toArray(new MyClass[0]);

我更喜欢第二种风格,因为它不太冗长,而且我假设编译器将确保空数组不会真正被创建,但我一直想知道这是否属实。

当然,在 99% 的情况下,这两种方式都没有什么区别,但我希望在正常代码和优化的内部循环之间保持一致的风格...

最佳答案

与直觉相反,Hotspot 8 上最快的版本是:

MyClass[] arr = myList.toArray(new MyClass[0]);

我使用 jmh 运行了一个微基准测试,结果和代码如下,显示具有空数组的版本始终优于具有预先调整大小的数组的版本。请注意,如果您可以重复使用正确大小的现有数组,结果可能会有所不同。

基准测试结果(以微秒为单位的分数,越小=越好):

Benchmark                      (n)  Mode  Samples    Score   Error  Units
c.a.p.SO29378922.preSize 1 avgt 30 0.025 ▒ 0.001 us/op
c.a.p.SO29378922.preSize 100 avgt 30 0.155 ▒ 0.004 us/op
c.a.p.SO29378922.preSize 1000 avgt 30 1.512 ▒ 0.031 us/op
c.a.p.SO29378922.preSize 5000 avgt 30 6.884 ▒ 0.130 us/op
c.a.p.SO29378922.preSize 10000 avgt 30 13.147 ▒ 0.199 us/op
c.a.p.SO29378922.preSize 100000 avgt 30 159.977 ▒ 5.292 us/op
c.a.p.SO29378922.resize 1 avgt 30 0.019 ▒ 0.000 us/op
c.a.p.SO29378922.resize 100 avgt 30 0.133 ▒ 0.003 us/op
c.a.p.SO29378922.resize 1000 avgt 30 1.075 ▒ 0.022 us/op
c.a.p.SO29378922.resize 5000 avgt 30 5.318 ▒ 0.121 us/op
c.a.p.SO29378922.resize 10000 avgt 30 10.652 ▒ 0.227 us/op
c.a.p.SO29378922.resize 100000 avgt 30 139.692 ▒ 8.957 us/op
<小时/>

供引用,代码:

@State(Scope.Thread)
@BenchmarkMode(Mode.AverageTime)
public class SO29378922 {
@Param({"1", "100", "1000", "5000", "10000", "100000"}) int n;
private final List<Integer> list = new ArrayList<>();
@Setup public void populateList() {
for (int i = 0; i < n; i++) list.add(0);
}
@Benchmark public Integer[] preSize() {
return list.toArray(new Integer[n]);
}
@Benchmark public Integer[] resize() {
return list.toArray(new Integer[0]);
}
}
<小时/>

您可以在博客文章 Arrays of Wisdom of the Ancients 中找到类似的结果、完整的分析和讨论。 。总结一下:JVM 和 JIT 编译器包含多项优化,使其能够以低廉的成本创建和初始化新的正确大小的数组,而如果您自己创建数组,则无法使用这些优化。

关于java - .toArray(new MyClass[0]) 或 .toArray(new MyClass[myList.size()])?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/59210547/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com