开发者

does a Java getter incur a performance penalty

开发者 https://www.devze.com 2022-12-25 14:04 出处:网络
if i have the code int g开发者_StackOverflowetA(){ return a; } and then do something like int b = obj.getA();

if i have the code

int g开发者_StackOverflowetA(){
 return a;
}

and then do something like

int b = obj.getA();

instead of

int b = obj.a;

will that mean that the stack will have to be pushed and popped ultimately slowing down my code?


The JIT compiler will inline the method.

The code should look like

int b = obj.GetA();


I have two answers for you:

  1. I don't think that there is a significant performance penalty for using the getter vs accessing the variable directly. I would worry more about how understandable and readable the code is than performance for this sort of decision.
  2. According to OO design principles, which may or may not be important to you, you would normally hide the data and provide the getter method to access it—there is a detailed discussion on the merits of this approach here.


Theoretically there is some runtime penalty, due to a method call being made. In reality, this has very little effect on the overall performance due to two reasons:

  1. Unless the obj.getA() is taking place inside the inner-most loop of your program, then its effect on the overall performance of your code will be negligible. When performance is an issue you should consider the bottleneck of your code. There's no point in optimizing code that is out not at these hot spots. In order to identify these spots you need to analyze the execution of your code via a profiler.
  2. As @Michael was saying the JVM uses a "Just In Time" compiler/optimizer that inlines code based on actual execution. It performs just this kind of optimizations (see this talk)
0

精彩评论

暂无评论...
验证码 换一张
取 消