Java JVM能否优化阵列中的多个读取
当多次读取同一索引时,JVM能否优化数组读取?考虑以下事项:Java JVM能否优化阵列中的多个读取,java,jvm,java-memory-model,Java,Jvm,Java Memory Model,当多次读取同一索引时,JVM能否优化数组读取?考虑以下事项: public static void foo(int[] array) { for (int i=0; i<array.length; i++) { int value1 = array[i]; ... int value2 = array[i]; ... } ... } publicstaticvoidfoo(int[]数组){ 对于(int i=
public static void foo(int[] array) {
for (int i=0; i<array.length; i++) {
int value1 = array[i];
...
int value2 = array[i];
...
}
...
}
publicstaticvoidfoo(int[]数组){
对于(int i=0;iYes),优化器只考虑单线程数据流,它不关心变量是否被另一个线程更改,除非涉及volatile/synchronized
即使没有优化,第二次读取也应该非常快,大约1ns,因为数据最有可能在一级缓存中。我不认为JVM会优化此读取,但是daload
操作的开销应该是微不足道的
如果您只想从数组中读取一次值,请尝试分配给局部变量(消耗一些微不足道的局部变量堆栈内存)
测试应该证明更改是任意的。我们可以假设您询问的是热点虚拟机吗?这实际上是一个关于Java内存模型的问题。JVM供应商无关紧要。实际上,它将是Sun的热点JVM。
int origVal = array[i];
int value1 = origVal;
...
int value2 = origVal;