他们两个几乎都做同样的事情。确定该方法很热,然后编译而不是解释。使用OSR,您只需在编译后立即转到编译版本,而不像JIT,后者是在第二次调用该方法时调用已编译的代码。
除此之外,还有其他区别吗?
通常, 即时 编译是指在运行时编译本机代码并执行它,而不是(或除了)进行解释。某些虚拟机(例如Google
V8)甚至都没有解释器;这些虚拟机甚至没有解释器。他们通过JIT编译执行的每个函数(优化程度各不相同)。
堆栈替换(OSR)是一种用于在同一功能的不同实现之间进行切换的技术。例如,您可以使用OSR在编译完成后立即将其从解释后的代码或未优化的代码切换为JIT代码。
OSR在您将某个函数运行时将其标识为“热”的情况下很有用。这可能不一定是因为函数被频繁调用。它可能只被调用一次,但是它花了很多时间在一个大循环中,这可以从优化中受益。发生OSR时,VM暂停,目标函数的堆栈框架被等效框架替换,该等效框架可能在不同位置具有变量。
OSR也可能发生在另一个方向:从优化代码到未优化代码或解释代码。优化的代码可能会基于过去的行为对程序的运行时行为做出一些假设。例如,如果您只看过一种类型的接收器对象,则可以将虚拟或动态方法调用转换为静态调用。如果以后发现这些假设是错误的,则可以使用OSR退回到更为保守的实现方式:将优化的堆栈框架转换为未优化的堆栈框架。如果虚拟机支持内联,则您甚至可能最终将优化的堆栈帧转换为
几个 未优化的堆栈帧。
问题内容: 他们两个几乎都做同一件事。确定该方法很热,然后编译而不是解释。使用OSR,您只需在编译后立即转到编译版本,而不像JIT,后者是在第二次调用该方法时调用已编译的代码。 除此之外,还有其他区别吗? 问题答案: 通常,即时编译是指在运行时编译本机代码并执行它,而不是(或除了)进行解释。某些虚拟机(例如Google V8)甚至都没有解释器;这些虚拟机甚至没有解释器。他们通过JIT编译执行的每个
问题内容: 在Java多线程中,术语和之间在语义上有区别吗? 问题答案: 每个线程都有自己的调用堆栈,“调用堆栈”和“线程堆栈”是同一件事。将其称为“线程堆栈”只是强调了调用堆栈特定于线程。 Bill Venners将此称为Java堆栈: 启动新线程时,Java虚拟机将为该线程创建一个新的Java堆栈。如前所述,Java堆栈将线程的状态存储在离散的帧中。Java虚拟机仅直接在Java堆栈上执行两项
考虑以下代码: 当 C2 OSR 编译开始时,热点 JVM 是否能够在堆栈上标量化 ?我想这可能是有问题的,因为活动对象已经存在于堆中,所以可能无法将对象从堆“移动”到堆栈和寄存器。
问题内容: 即时编译器和解释器之间有什么区别,.NET和Java JIT编译器之间有什么区别? 问题答案: 即时编译是在执行之前将非本机代码(例如字节码)转换为本机代码。 从维基百科: JIT基于运行时环境中的两个较早的想法:字节码编译和动态编译。它在本地执行代码之前先在运行时将其转换,例如将字节码转换为本地机器代码。 一种解释执行程序。它可能有也可能没有抖动。 同样,来自维基百科: 解释器可能是
问题内容: 最终变量和编译时间常数之间有什么区别? 考虑以下代码 这是什么意思?何时以及如何为最终变量分配值?在运行时会发生什么,在编译时会发生什么?为什么要给switch一个编译时间常数?Java还有哪些其他结构需要编译时间常数? 问题答案: 问题在于, 所有语句在编译时 都 必须是最终的 。您的第一个陈述 是最终决定 。对于100%,除以外没有其他值。 然而,这 不能保证 对。如果周围有一个i
本文向大家介绍Java中的堆栈和堆内存之间的区别,包括了Java中的堆栈和堆内存之间的区别的使用技巧和注意事项,需要的朋友参考一下 JVM将内存空间分为两部分,一个是堆栈,另一个是堆空间。堆栈空间主要用于存储方法执行的顺序和局部变量。 堆栈始终按照LIFO顺序存储块,而堆内存使用动态分配来分配和取消分配内存块。 分配给堆的内存将一直存在,直到发生以下事件之一: 程序终止 无记忆 相反,分配给