Is it faster to access final local variables than class variables in Java?

前端 未结 5 1776
闹比i
闹比i 2020-12-06 01:07

I\'ve been looking at at some of the java primitive collections (trove, fastutil, hppc) and I\'ve noticed a pattern that class variables are sometimes declared as fina

5条回答
  •  醉梦人生
    2020-12-06 01:55

    Accessing local variable or parameter is a single step operation: take a variable located at offset N on the stack. If you function has 2 arguments (simplified):

    • N = 0 - this
    • N = 1 - first argument
    • N = 2 - second argument
    • N = 3 - first local variable
    • N = 4 - second local variable
    • ...

    So when you access local variable, you have one memory access at fixed offset (N is known at compilation time). This is the bytecode for accessing first method argument (int):

    iload 1  //N = 1
    

    However when you access field, you are actually performing an extra step. First you are reading "local variable" this just to determine the current object address. Then you are loading a field (getfield) which has a fixed offset from this. So you perform two memory operations instead of one (or one extra). Bytecode:

    aload 0  //N = 0: this reference
    getfield total I  //int total
    

    So technically accessing local variables and parameters is faster than object fields. In practice, many other factors may affect performance (including various levels of CPU cache and JVM optimizations).

    final is a different story. It is basically a hint for the compiler/JIT that this reference won't change so it can make some heavier optimizations. But this is much harder to track down, as a rule of thumb use final whenever possible.

提交回复
热议问题