我知道方法上final
关键字的一种用法是强制子类使用相同的方法实现。但是,通过允许编译器将对方法的调用转换为内联java代码来提高效率意味着什么呢?我刚读过这篇文章,但并不完全理解这个想法。
在这种程度上,我不了解内联Java代码的含义。如何执行对final
方法的调用?在编译调用final
方法的代码时,Java是否通知或执行了哪些特殊操作?
答案 0 :(得分:5)
如果使用final,字节码的效率可能没那么高效或低效,因为Java字节码编译器通常在优化方式上做的很少。效率奖励(如果有的话)将在JIT编译器生成的本机代码中。
理论上,使用final可以为JIT编译器提供一个有助于优化的提示。在实践中,最近的HotSpot JIT编译器可以通过忽略您的提示来做得更好。例如,现代JIT编译器通常执行全局分析以查明给定方法调用是否是在应用程序当前加载的类的上下文中对叶方法的调用。此分析比最终提示更准确,运行时甚至可以检测何时加载新类使分析无效...并重新生成受影响代码的分析和本机代码生成。
因此,最佳做法是使用final来(广泛地说)表达您的设计意图,并实现您需要的其他语义效果。 (例如,使用final修饰符可以在实现线程安全的不可变类型中发挥重要作用。)如果使用final作为优化提示,则不会实现太多,并且您将使代码更难以修改和扩展
font:link
答案 1 :(得分:1)
当你想知道Java编译器如何处理不同的结构时,找到的一个好方法是使用javap
来反汇编类文件。
最终方法可能提供优化机会,因为将在编译时知道将运行的代码。否则,必须在运行时执行查找,以确定要运行的版本(原始版本或覆盖版本)。
这是理论......在实践中,现有的Java编译器不会进行非常积极的优化。