gpt4 book ai didi

JAVA字节码优化

转载 作者:行者123 更新时间:2023-11-29 07:11:23 24 4
gpt4 key购买 nike

这是一个基本问题。

我有不应在元数据 bean 上运行的代码。所有元数据 bean 都位于元数据包下。

现在,

我使用反射 API 来查明某个类是否位于元数据包中。

if (newEntity.getClass().getPackage().getName().contains("metadata")) 

我在这段代码中的几个地方使用了这个 If。

问题是:我应该这样做一次吗:

boolean isMetadata = false
if (newEntity.getClass().getPackage().getName().contains("metadata")) {
isMetadata = true;
}

C++做了优化,知道这段代码已经被调用过,不会再调用了。 JAVA做优化吗?我知道反射 API 很重,我更喜欢不要失去昂贵的运行时间。

最佳答案

在将任何工作投入优化之前,您当然应该检查是否真的存在性能问题。 getClass() 可能已经相当快了(无论如何比 instanceof 快)。您可能会缓存元数据包中的一组类,这样您就不需要一直检查包名称。

如果你真的需要比较包,你可以找到元数据包一次,使用 Package.getPackage(String name)方法,然后对于每个对象,像以前一样调用 getClass().getPackage(),并比较两个包对象。

这比检查包名称中的字符串更快更优雅,但如果有多个类加载器,则可能无法正常工作,因为包对象不相等 (== ) 并且 Package 不会覆盖 .equals()。考虑一下,它甚至可能不能保证在单个类加载器上工作,但我怀疑在实践中你会得到相同的 Package 实例而不是另一个副本 - 首先检查一下是明智的!,例如:

String.class.getPackage() == Integer.class.getPackage() // should be true

更新 如果您检查 source code对于 Class.getPackage()Package.getPackage()ClassLoader.getPackage() 你可以看到它们缓存了 Package 对象,因此在使用单个类加载器时比较它们应该是安全的

包命名约定的一个问题是您必须在整个代码库中强制执行和维护它,随着时间的推移,这可能会成为维护问题。一种更明确的识别类的方法可能会更好。

识别特定类组的替代方法包括:

  • 让您的元数据 bean 实现标记接口(interface)
  • 使用 Java Annotations 标记元数据 bean
  • 所有 bean 实现一个公共(public)接口(interface),该接口(interface)带有一个方法,可以调用该方法来检查它们是否属于您定义的特定类别。这很难看,因为它基本上是在复制类型系统,但会很快,因为它不需要反射。

关于JAVA字节码优化,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/13550178/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com