Различия между сборкой Just in Time и заменой на стек - PullRequest
38 голосов
/ 02 февраля 2012

Оба они в значительной степени делают одно и то же.Определите, что метод горячий, и скомпилируйте его вместо интерпретации.В OSR вы просто переходите к скомпилированной версии сразу после ее компиляции, в отличие от JIT, где скомпилированный код вызывается при повторном вызове метода.

Кроме этого, есть ли другие различия?

Ответы [ 2 ]

58 голосов
/ 02 февраля 2012

В общем, Компиляция точно в срок означает компиляцию собственного кода во время выполнения и выполнение его вместо (или в дополнение к) интерпретации. Некоторые виртуальные машины, такие как Google V8, даже не имеют переводчика; они JIT компилируют каждую выполняемую функцию (с различной степенью оптимизации).

On Stack Replacement (OSR) - это метод для переключения между различными реализациями одной и той же функции. Например, вы можете использовать OSR для переключения с интерпретируемого или неоптимизированного кода на код JITed, как только он завершит компиляцию.

OSR полезна в ситуациях, когда вы определяете функцию как «горячую» во время ее работы. Это не обязательно может быть потому, что функция вызывается часто; он может быть вызван только один раз, но он проводит много времени в большом цикле, который может выиграть от оптимизации. Когда происходит OSR, виртуальная машина приостанавливается, и кадр стека для целевой функции заменяется эквивалентным кадром, который может иметь переменные в разных местах.

OSR также может происходить в другом направлении: от оптимизированного кода до неоптимизированного кода или интерпретируемого кода. Оптимизированный код может сделать некоторые предположения о поведении программы во время выполнения на основе прошлого поведения. Например, вы можете преобразовать виртуальный или динамический вызов метода в статический вызов, если вы когда-либо видели только один тип объекта-получателя. Если позже окажется, что эти предположения были неверны, OSR можно использовать для возврата к более консервативной реализации: оптимизированный кадр стека преобразуется в неоптимизированный кадр стека. Если виртуальная машина поддерживает встраивание, вы можете даже преобразовать оптимизированный кадр стека в несколько неоптимизированных кадров стека.

11 голосов
/ 02 февраля 2012

Да, вот и все. Своевременная компиляция может повысить производительность, компилируя «горячие точки» (точки байт-кода, которые известны / должны выполняться очень часто) байт-кода в нативные инструкции. Замена на стеке дополняет возможности JIT, заменяя долго исполняемый интерпретируемый «горячий» байт-код его скомпилированной версией, когда она становится доступной.В упомянутой статье On-Stack Replacement приведен хороший пример, когда JIT-компиляция была бы не очень полезна без OSR.

...