JVM何时使用内在函数

为什么在JVM内部类中存在的某些代码模式被转换为内部函数,而从我自己的类调用时相同的模式则不然。

例:

bitCount函数,当从Integer.bitCount(i)内调用时,将变成一个内在函数。 但是当复制到我的类中然后调用将需要更长的时间来执行。

比较

Integer.bitCount(i) MyClass.bitCount(i) public static int bitCount(int i) { // HD, Figure 5-2 i = i - ((i >>> 1) & 0x55555555); i = (i & 0x33333333) + ((i >>> 2) & 0x33333333); i = (i + (i >>> 4)) & 0x0f0f0f0f; i = i + (i >>> 8); i = i + (i >>> 16); return i & 0x3f; } 

答案很简单:以这种方式定义内部函数,因为存在获得函数结果的更快的本机方式,并且由于指定的映射而应用它。

这根本不是与编译有关的东西。 Integer.bitCount是特殊的,因为实现被标记为可以用本机asm指令POPCNT替换。 基本上,当使用Integer.bitCount函数(如果CPU支持该指令)时使用此本机指令,当您声明自己的函数副本时,使用正常实现。

为什么JVM能够识别出可以优化该function? 因为它在JDK中的某个地方是硬编码的,所以与代码的相似性无关。

JVM有一个方法列表,通常是本机方法,它取代了内联的机器代码。 此列表出现在OpenJDK的内部头文件中,但我无法在Web上找到它的链接。

请参阅链接@Jack提供的vmSymbols.hpp中的第581行