JVM(特别是HotSpot VM)以其在运行时可以应用的大量优化而闻名.
有没有办法看一下某段代码,看看JVM实际上做了什么?
解决方法
一个问题是“JVM实际上做了什么”会在调用之间改变,因为JVM可以自由地重新生成代码.
作为一个例子,我调查了几天前Hotspot与虚拟方法相比的最终方法.根据微观基准,我的结论是:
>客户端JVM:如果方法有效地是最终的(没有任何加载的类覆盖它),则JVM使用非虚拟调用.之后,如果加载覆盖此方法的类,则JVM将更改JIT的代码以使调用成为虚函数.所以宣称最终没有显着的相关性.
>服务器JVM:这里的final似乎也没有关联.似乎发生的情况是,JVM为您第一次使用的任何类生成一个非虚拟调用,与任何加载的类无关.之后,如果您从另一个类的对象进行调用,则JVM会使用与此类似的类型对所有调用进行修补(我猜也会对调用进行调用,以便如果没有获得更改快速路径和慢速路径正确的第一次):
if (object instanceof ClassOfNonVirtualCall) { do non-virtual call to ClassOfNonVirtualCall.method } else { do virtual call to object.method }
如果您真的有兴趣看到生成的代码,可以使用OpenJDK中的DEBUG JVM: