我想知道为什么立即分配一个2D int数组(new int[50][2]
)比单独分配执行更差,即先执行new int[50][]
,然后再执行new int[2]
一个接一个。这里是一个非专业的基准代码:2D阵列分配的性能
public class AllocationSpeed {
private static final int ITERATION_COUNT = 1000000;
public static void main(String[] args) {
new AllocationSpeed().run();
}
private void run() {
measureSeparateAllocation();
measureAllocationAtOnce();
}
private void measureAllocationAtOnce() {
Stopwatch stopwatch = Stopwatch.createStarted();
for (int i = 0; i < ITERATION_COUNT; i++) {
allocateAtOnce();
}
stopwatch.stop();
System.out.println("Allocate at once: " + stopwatch);
}
private int allocateAtOnce() {
int[][] array = new int[50][2];
return array[10][1];
}
private void measureSeparateAllocation() {
Stopwatch stopwatch = Stopwatch.createStarted();
for (int i = 0; i < ITERATION_COUNT; i++) {
allocateSeparately();
}
stopwatch.stop();
System.out.println("Separate allocation: " + stopwatch);
}
private int allocateSeparately() {
int[][] array = new int[50][];
for (int i = 0; i < array.length; i++) {
array[i] = new int[2];
}
return array[10][1];
}
}
我在64位Linux测试,这些结果与不同的64位甲骨文的Java版本:
1.6.0_45-B06:
Separate allocation: 401.0 ms
Allocate at once: 1.673 s
1.7.0_45-B18
Separate allocation: 408.7 ms
Allocate at once: 1.448 s
1.8.0-EA-b 115
Separate allocation: 380.0 ms
Allocate at once: 1.251 s
只是出于好奇,我的OpenJDK 7以及(其中的差异更小)试了一下:
Separate allocation: 424.3 ms
Allocate at once: 1.072 s
对我来说,这是相当反直觉的,我希望分配在一次快点。
我已经尝试了不同的尺寸和对象[] []',没有任何改变。要么我真的很盲目,要么你发现了一些有趣的事情。或者JIT取消了我们的部分工作。 – maaartinus