Předběžná kompilace - Ahead-of-time compilation

V počítačové vědě předběžná kompilace (AOT kompilace) je akt kompilace vyšší úroveň programovací jazyk jako C nebo C ++, nebo mezilehlé zastoupení jako Bajtový kód Java nebo .NET Framework Společný střední jazyk (CIL) kód do nativního (závisí na systému) strojový kód aby se výsledný binární soubor mohl nativně spustit.

AOT produkuje strojově optimalizovaný kód, stejně jako Standard nativní překladač. Rozdíl je v tom, že AOT transformuje bytecode existujícího virtuální stroj (VM) do strojový kód.

Snížená runtime režie

Některé programovací jazyky s a spravovaný kód běhový modul, který lze zkompilovat do mezilehlé reprezentace, použijte právě včas (JIT) kompilace. Toto stručně zkompiluje mezilehlý kód do strojového kódu pro nativní běh při provádění mezilehlého kódu, což může zpomalit výkon aplikace. Předběžné kompilace eliminuje potřebu tohoto kroku tím, že nastane před spuštěním, nikoli během provádění.

Předběžné kompilace pro dynamicky zadáno jazyky k nativnímu strojovému kódu nebo jinému statickému bytekódu VM je možný pouze v omezeném počtu případů.[Citace je zapotřebí ] Například kompilátor AOT High Performance Erlang Project (HiPE) pro daný jazyk Erlang to může udělat díky pokročilým technikám rekonstrukce statického typu a spekulacím s typem.

Ve většině situací s plně zkompilovanými programy a knihovnami AOT je možné zrušit užitečný zlomek a běhové prostředí, čímž se šetří místo na disku, paměť, výdrž baterie a doby spuštění (bez zahřívací fáze JIT) atd. Z tohoto důvodu může být užitečné ve vestavěných nebo mobilních zařízeních.

Výkonové kompromisy

Překladače AOT mohou provádět složitý a pokročilý kód optimalizace, což bude ve většině případů JITingu považováno za příliš nákladné. Naproti tomu AOT obvykle nemůže provádět některé optimalizace možné v JIT, jako je runtime profilová optimalizace (PGO), pseudo-konstantní šíření, nebo nepřímévirtuální funkce vložka. AOT musí kompilovat do cílové architektury, zatímco JIT může kompilovat kód, aby co nejlépe využil skutečný CPU, na kterém běží, a to i roky po vydání softwaru.

Dále mohou kompilátoři JIT spekulativně optimalizovat horký kód vytvořením předpokladů v kódu. Vygenerovaný kód lze optimalizovat, pokud se později ukáže spekulativní předpoklad. Taková operace zpomaluje výkon spuštěného softwaru, dokud není kód znovu optimalizován pomocí adaptivní optimalizace. Kompilátor AOT nemůže takové předpoklady vytvořit a musí vyvodit co nejvíce informací v době kompilace. Musí se uchýlit k méně specializovanému kódu, protože nemůže vědět, jaké typy projdou metodou. Takové problémy lze zmírnit optimalizacemi podle profilu. Ale i v tomto případě nelze vygenerovaný kód dynamicky přizpůsobit měnícímu se běhovému profilu, jak by to udělal kompilátor JIT.

Viz také

Reference

externí odkazy