微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

java – 访问器方法性能和优化

通常,我会遇到代码,其中重复使用/滥用Getter方法获取某些值或将其作为方法参数传递,例如:
public class Test {
   public void someMethod() {
      if(person.getName() != null && person.getName().equalsIgnoreCase("Einstein")) {
           method1(person.getName());
      }
      method2(person.getName());
      method3(person.getName());
      method4(person.getName());
   }
}

我通常编码,如下所示:

public class Test {
   public void someMethod() {
      String name = person.getName();
      if(name != null && name.equalsIgnoreCase("Einstein")) {
           method1(name);
      }
      method2(name);
      method3(name);
      method4(name);
   }

在我看来,将getter分配给变量并使用它有很大的内存/性能优势,因为Getters是Java方法并使用堆栈帧.编码方式真的有相当大的优势吗?
}

解决方法

您最近是否了解过您的意见.

性能

这可能是一个微观优化,在1999-2001之前的1.2 JVM中需要关注的事情,即使这样,我也会质疑它,除非一些严肃的数字显示不同.

现代JIT实施会告诉您,今天您的意见不合适.

现代编译器实现会进行各种优化,这使得在这样的事情上思考会浪费Java时间. JIT只是让人更加担心.

逻辑:

在并发情况下,如果要查看更改,则两个代码块在逻辑上不等同,使本地副本可以防止这种情况发生.根据您的想法,一种或另一种方法可能会产生非常微妙的非确定性错误,这些错误在更复杂的代码中很难确定.

特别是如果返回的内容是可变的,而不像String是不可变的.然后,即使是本地副本也可能会发生变化,除非你做了深度克隆,并且很快就会很容易出错.

关注自己正确地做,然后测量然后优化重要的东西,只要它不会使代码不易维护.

如果除了返回this.name之外的方法调用中没有任何内容,JVM将内联对最终实例成员的任何调用删除方法调用;它知道访问器方法中没有逻辑,并且它知道引用是最终的,因此它知道它可以内联该值,因为它不会改变.

为此目的

person.getName() != null && person.getName().equalsIgnoreCase("Einstein")

被更正确地表达为

person != null && "Einstein".equalsIgnoreCase(person.getName())

因为没有机会出现NullPointerException

重构:

现代IDE重构工具删除了有关必须在一堆地方更改代码的任何争论.

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


应用场景 C端用户提交工单、工单创建完成之后、会发布一条工单创建完成的消息事件(异步消息)、MQ消费者收到消息之后、会通知各处理器处理该消息、各处理器处理完后都会发布一条将该工单写入搜索引擎的消息、最终该工单出现在搜索引擎、被工单处理人检索和处理。 事故异常体现 1、异常体现 从工单的流转记录发现、
线程类,设置有一个公共资源 package cn.org.chris.concurrent; import java.util.concurrent.locks.Lock; import java.util.concurrent.locks.ReentrantLock; /** * @Descrip
Java中的数字(带有0前缀和字符串)
在Java 9中使用JLink的目的是什么?
Java Stream API Filter(过滤器)
在Java中找到正数和负数数组元素的数量
Java 9中JShell中的不同启动脚本是什么?
使用Java的位填充错误检测技术
java中string是什么
如何使用Java中的JSON-lib API将Map转换为JSON对象?