即時編譯器(JIT)的編譯過程是什么?

1. 觸發編譯

JIT編譯的觸發基于熱點代碼檢測,主要通過兩種計數器:
? 方法調用計數器:統計方法被調用的次數(默認閾值:C1為1,500次,C2為10,000次)。
? 回邊計數器:統計循環體的執行次數(如forwhile中的跳轉指令)。

當計數器超過閾值時,JVM將代碼加入編譯隊列,由后臺編譯線程處理。


2. 編譯流程(以HotSpot JVM為例)

JIT的編譯過程分為多個階段,不同編譯器(C1/C2/Graal)細節略有差異,但核心流程相似:

(1) 字節碼解析與中間表示(IR)生成

? 輸入:字節碼(.class文件中的指令)。
? 輸出:生成高級中間表示(HIR),如控制流圖(CFG)。
? 關鍵操作
? 解析字節碼,構建基本塊(Basic Block)。
? 識別循環結構、異常處理塊等。

(2) 方法內聯(Method Inlining)

? 優化目標:減少方法調用開銷。
? 規則
? 內聯小方法(如getter/setter)。
? 避免內聯巨型方法(通過-XX:MaxInlineSize=35控制閾值)。
? 示例

// 內聯前
int getValue() { return value; }
void print() { System.out.println(getValue()); }// 內聯后
void print() { System.out.println(value); }

(3) 逃逸分析(Escape Analysis)

? 目標:判斷對象是否僅在方法內部使用。
? 優化結果
? 棧上分配:對象直接分配在棧幀,減少GC壓力。
? 標量替換:將對象拆解為基本類型局部變量。
? 鎖消除:若對象無競爭,移除同步操作。
? 示例

// 優化前
void foo() {Object obj = new Object();  // 對象可能被分配在堆synchronized(obj) { ... }   // 同步鎖
}// 優化后(逃逸分析確認obj未逃逸)
void foo() {// 對象被標量替換或棧上分配,鎖被消除
}

(4) 循環優化

? 循環展開(Loop Unrolling):減少循環條件判斷次數。

// 優化前
for (int i = 0; i < 4; i++) { sum += i; }// 優化后
sum += 0; sum += 1; sum += 2; sum += 3;

? 循環向量化(SIMD):利用CPU單指令多數據(如AVX指令)并行計算數組。

(5) 公共子表達式消除(CSE)

? 移除冗余計算:復用相同表達式的計算結果。

// 優化前
int a = x * y + z;
int b = x * y + w;// 優化后
int tmp = x * y;
int a = tmp + z;
int b = tmp + w;

(6) 死代碼消除(Dead Code Elimination)

? 移除不可達代碼:如if (false) { ... }或未使用的變量。

// 優化前
int x = 1;
if (false) { x = 2; }  // 死代碼
System.out.println(x);// 優化后
System.out.println(1);

(7) 本地代碼生成

? 目標平臺適配:根據CPU架構(x86/ARM)生成機器碼。
? 寄存器分配:優化寄存器使用,減少內存訪問。
? 指令選擇:選擇高效指令(如用LEA替代乘法)。


3. 分層編譯(Tiered Compilation)

現代JVM(如HotSpot)采用分層策略逐步優化代碼:

  1. 第0層:解釋執行(快速啟動)。
  2. 第1層(C1編譯器):輕量優化(方法內聯、簡單循環展開)。
  3. 第2層(C2編譯器):深度優化(逃逸分析、向量化)。
  4. Graal編譯器(可選):替代C2,支持更激進優化(如JDK17的GraalVM)。

觸發條件
? C1編譯:方法調用約1,500次(-XX:CompileThreshold)。
? C2編譯:方法調用約10,000次(-XX:Tier4CompileThreshold)。


4. 反優化(Deoptimization)

當假設條件不滿足時,JVM會回退到解釋執行,常見場景:
? 類加載變化:如動態加載新類導致原有優化失效。
? 多態調用:虛方法的目標方法改變(如接口實現類新增)。
? 斷言失敗:逃逸分析假設被打破(對象意外逃逸)。


5. 監控與調優

(1) 查看JIT編譯日志

java -XX:+PrintCompilation -XX:+PrintInlining -XX:+UnlockDiagnosticVMOptions MyApp

輸出示例

42   3    java.lang.String::hashCode (55 bytes)   COMPILE SKIPPED: already compiled
56   1    java.util.ArrayList::size (5 bytes)   INLINE (hot)

(2) 關鍵JVM參數

參數作用
-XX:+TieredCompilation啟用分層編譯(默認開啟)
-XX:CompileThreshold=1500調整C1編譯的調用閾值
-XX:MaxInlineSize=35控制方法內聯的最大字節碼大小
-XX:+PrintAssembly打印生成的機器碼(需HSDIS插件)

6. 實際案例:優化斐波那契數列

原始代碼(遞歸)

long fib(int n) {if (n <= 1) return n;return fib(n-1) + fib(n-2);  // 重復計算,性能差
}

JIT優化后

  1. 內聯:遞歸調用被展開。
  2. 循環展開:轉換為迭代形式。
  3. 最終機器碼:近似以下優化版本:
    long fib(int n) {if (n <= 1) return n;long a = 0, b = 1;for (int i = 2; i <= n; i++) {long c = a + b;a = b;b = c;}return b;
    }
    

性能提升:從指數級時間復雜度(O(2^n))降至線性(O(n))。


7. 總結

? 觸發條件:基于熱點代碼的調用或循環次數。
? 核心優化:方法內聯、逃逸分析、循環優化、死代碼消除等。
? 分層編譯:逐步從解釋執行過渡到深度優化(C1→C2)。
? 反優化:動態適應運行時變化,保證正確性。
? 調優建議:監控編譯日志,合理配置閾值,避免冷啟動影響性能測試。

理解JIT編譯過程有助于編寫對編譯器友好的代碼(如小方法、減少動態綁定),最大化運行時性能。

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/web/75606.shtml
繁體地址,請注明出處:http://hk.pswp.cn/web/75606.shtml
英文地址,請注明出處:http://en.pswp.cn/web/75606.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

Java基礎:集合List、Map、Set(超詳細版)

集合體系概述 Collection常用方法 補充&#xff1a;addAll() Collection的遍歷方式 迭代器 增強for&#xff08;空集合可以&#xff0c;null不可以&#xff09; lambda 集合對象存儲對象原理 遍歷方式的區別 List集合 特點、特有方法 遍歷方式 &#xff08;同上&#xff09…

Elasticsearch 全面解析

Elasticsearch 全面解析 前言一、簡介核心特性應用場景 二、核心原理與架構設計1. 倒排索引&#xff08;Inverted Index&#xff09;2. 分片與副本機制&#xff08;Sharding & Replication&#xff09;3. 節點角色與集群管理 三、核心特點1. 靈活的查詢語言&#xff08;Que…

【2】k8s集群管理系列--包應用管理器之helm(Chart語法深入應用)

一、Chart模板&#xff1a;函數與管道 常用函數&#xff1a; ? quote&#xff1a;將值轉換為字符串&#xff0c;即加雙引號 ? default&#xff1a;設置默認值&#xff0c;如果獲取的值為空則為默認值 ? indent和nindent&#xff1a;縮進字符串 ? toYaml&#xff1a;引用一…

JVM 字節碼是如何存儲信息的?

JVM 字節碼是 Java 虛擬機 (JVM) 執行的指令集&#xff0c;它是一種與平臺無關的二進制格式&#xff0c;在任何支持 JVM 的平臺上都可運行的Java 程序。 字節碼存儲信息的方式&#xff0c;主要通過以下幾個關鍵組成部分和機制來實現&#xff1a; 1. 指令 (Opcodes) 和 操作數 …

基于51單片機語音實時采集系統

基于51單片機語音實時采集 &#xff08;程序&#xff0b;原理圖&#xff0b;PCB&#xff0b;設計報告&#xff09; 功能介紹 具體功能&#xff1a; 系統由STC89C52單片機ISD4004錄音芯片LM386功放模塊小喇叭LCD1602按鍵指示燈電源構成 1.可通過按鍵隨時選擇相應的錄音進行播…

關于 Java 預先編譯(AOT)技術的詳細說明,涵蓋 GraalVM 的配置、Spring Boot 3.x 的集成、使用示例及優缺點對比

以下是關于 Java 預先編譯&#xff08;AOT&#xff09;技術的詳細說明&#xff0c;涵蓋 GraalVM 的配置、Spring Boot 3.x 的集成、使用示例及優缺點對比&#xff1a; 1. 預先編譯&#xff08;AOT&#xff09;技術詳解 1.1 核心概念 AOT&#xff08;Ahead-of-Time&#xff09…

【ROS2】行為樹:BehaviorTree

1、簡介 與狀態機不同,行為樹強調執行動作,而不是狀態之間的轉換。 行為樹是可組合的。可以重復使用簡單的行為來構建復雜的行為。 在游戲領域,行為樹已經比較流行了。主要用于維護游戲角色的各種動作和狀態。 ROS2的導航框架Navigation2中引入了行為樹來組織機器人的工作流…

Centos7.9 升級內核,安裝RTX5880驅動

系統鏡像下載 https://vault.centos.org/7.9.2009/isos/x86_64/CentOS-7-x86_64-DVD-2009.iso 系統安裝步驟省略 開始安裝顯卡驅動 遠程登錄查看內核 [root192 ~]# uname -a Linux 192.168.119.166 3.10.0-1160.el7.x86_64 #1 SMP Mon Oct 19 16:18:59 UTC 2020 x86_64 x8…

多層感知機與全連接神經網絡關系解析

感知機&#xff08;Perceptron&#xff09;、多層感知機&#xff08;MLP&#xff0c;Multilayer Perceptron&#xff09;和全連接神經網絡&#xff08;FCNN&#xff0c;Fully Connected Neural Network&#xff09;是神經網絡發展過程中密切相關的概念&#xff0c;但它們有明確…

解析醫療器械三大文檔:DHF、DMR與DHR

醫療器械的 DHF、DMR 和 DHR 是質量管理體系&#xff08;QMS&#xff09;中的核心文件&#xff0c;貫穿產品全生命周期&#xff0c; 確保醫療器械的安全性、有效性和合規性。 一、三大文件的定義與法規依據 縮寫全稱法規依據&#xff08;以 FDA 為例&#xff09;核心目的DHF…

netty啟用websocket的壓縮機制

netty啟用websocket的壓縮機制 package com.aerotop.connector.websocket.base;import io.netty.channel.ChannelInitializer; import io.netty.channel.ChannelPipeline; import io.netty.channel.socket.SocketChannel; import io.netty.handler.codec.compression.JZlibDec…

可能存在特殊情況,比如控制臺顯示有延遲、緩沖問題等影響了顯示順序。

從控制臺輸出看&#xff0c;正常邏輯應是先執行 System.out.println(" 未處理異常演示 "); 輸出對應文本&#xff0c;再因 arr 為 null 訪問 length 觸發 NullPointerException 輸出異常信息。可能存在特殊情況&#xff0c;比如控制臺顯示有延遲、緩沖問題等影響…

第一節:React 基礎篇-React虛擬DOM原理及Diff算法優化策略

必考點&#xff1a;虛擬DOM樹對比&#xff08;同級比較、Key的作用、組件類型判斷&#xff09; 延伸&#xff1a;React 18中并發更新對Diff算法的影響 React虛擬DOM原理及Diff算法優化策略 虛擬DOM核心原理 概念&#xff1a; ? 虛擬DOM&#xff08;Virtual DOM&#xff09;…

Java spring mybatis面試題(200道),八股文

Java面試題 通過網盤分享的文件&#xff1a;面試題等2個文件 鏈接: https://pan.baidu.com/s/1Xw0PzkfAmL8uesYBvrW2-A?pwdpebt 提取碼: pebt mybatis相關 1、 什么是Mybatis&#xff1f; … 2 2、 Mybaits 的優點&#xff1a; … 2 3、 MyBatis 框架的缺點&#xff1a; ……

windows使用Python調用7-Zip【按大小分組】壓縮文件夾中所有文件

使用Python調用7-Zip【按大小分組】壓縮文件夾中所有文件 問題描述&#xff1a;方法前提條件任務完整代碼示例代碼如何工作&#xff1f; 問題描述&#xff1a; 我現在想把文件夾下的所有內容上傳到網盤&#xff0c;但是這個文件夾下的素材內容很多&#xff0c;使用分卷壓縮的話…

《Python星球日記》第26天:Matplotlib 可視化

名人說&#xff1a;路漫漫其修遠兮&#xff0c;吾將上下而求索。—— 屈原《離騷》 創作者&#xff1a;Code_流蘇(CSDN)&#xff08;一個喜歡古詩詞和編程的Coder&#x1f60a;&#xff09; 訂閱專欄&#xff1a;《Python星球日記》 目錄 一、Matplotlib 簡介1. 什么是 Matplo…

第1章 對大型語言模型的介紹

人類正處在一個關鍵轉折點。自2012年起&#xff0c;基于深度神經網絡的人工智能系統研發進入快速通道&#xff0c;將這一技術推向了新高度&#xff1a;至2019年底&#xff0c;首個能夠撰寫與人類文章真假難辨的軟件系統問世&#xff0c;這個名為GPT-2&#xff08;生成型預訓練變…

dcsdsds

我將為您在頁面頂部添加歡迎內容&#xff0c;同時保持整體風格的一致性。以下是修改后的代碼&#xff0c;主要修改了模板部分和對應的樣式&#xff1a; vue 復制 <template><div class"main-wrapper"><!-- 新增歡迎部分 --><div class"…

學習MySQL的第八天

海到無邊天作岸 山登絕頂我為峰 一、數據庫的創建、修改與刪除 1.1 引言 在經過前面七天對于MySQL基本知識的學習之后&#xff0c;現在我們從基本的語句命令開始進入綜合性的語句的編寫來實現特定的需求&#xff0c;從這里開始需要我們有一個宏觀的思想&…

Linux-內核驅動-中斷-key

DEV_NAME&#xff1a;設備名稱。 wg&#xff1a;等待隊列頭&#xff0c;用于同步。 condition&#xff1a;條件變量&#xff0c;用于等待和喚醒。 中斷處理函數 irq_handler&#xff1a;處理中斷請求&#xff0c;設置條件變量并喚醒等待隊列中的進程。 文件操作函數 open…