.NET8 AOT和JIT的效能,誰更高呢?

江湖評談發表於2023-12-13

一:
有人問:.NET8 AOT和JIT的效能,誰更高呢?
原文:.NET8 AOT和JIT的效能,誰更高呢?

其實這個答案非常明顯,那就是JIT的效能更高。為什麼?原因在哪?因為JIT是隨時可能分層編譯,動態PGO,CHRL,Non GC Heap,OSR。Quick等極致的最佳化措施(關於這些措施,可以參考公眾號(jianghupt)之前的文章,有詳細描述)。只要觸發了這些最佳化的條件。

但是AOT就不一樣了,它從一開始就被ILC編譯成了二進位制的原生程式碼,只要是被編譯成了獨立的可執行檔案,它的二進位制程式碼就不會再次被最佳化了。只能是第一次生成的結果,一直不停地執行。

也就是說AOT的程式碼不能進行執行時候的最大化的最佳化,但是JIT可以,而且持續性的極端最佳化,所以JIT的效能無疑是遠遠高於AOT的。


二:
既然JIT如此強悍,那麼AOT的存在有何意義呢?

首先獨立的可執行檔案是AOT的一大特色,也就是不帶任何的動態連結庫,單個的可執行檔案執行在任何.NET支援的平臺上面,清爽,乾淨,而且可移植性強。其次AOT雖然效能上比之JIT有差距,但是它第一次啟動是要高於JIT的。也就是說AOT的效能並不是拉胯,而是折中 了。這其實跟兩者的原理有關,AOT因為被編譯成了原生的二進位制程式碼,直接在相應的平臺上執行,類似於系統級語言的程式碼比如C/C++這種,所以它編譯好了之後,第一次執行的速度是比較快的。但是JIT就不同了,因為JIT第一次執行是遵循一個原則,即是快速的把MSIL編譯成機器碼,而儘可能最小化的最佳化。所以JIT的第一次執行效能是很成問題的。但是隨著時間推移,多次執行某個函式,或者多次呼叫程式某個功能,JIT的優勢就發揮出來了。趕上以至於超越了AOT。


三:
原文:.NET8 AOT和JIT的效能,誰更高呢?
對此,你有什麼看法呢?可以下方留言討論下

歡迎加入C#12/.NET8技術交流群

相關文章