JVM JVM->Java Virtual Machine:Java虛擬機,是一種用於計算設備的規範,它是一個虛構出來的電腦,是通過在實際的電腦上模擬模擬各種電腦功能來實現的。 基本認知: 1.JVM是用於運行Java代碼的假象電腦,主要有一套位元組碼指令集,一組寄存器,一個棧,一個垃圾回收, ...
JVM
JVM->Java Virtual Machine:Java虛擬機,是一種用於計算設備的規範,它是一個虛構出來的電腦,是通過在實際的電腦上模擬模擬各種電腦功能來實現的。
基本認知:
- 1.JVM是用於運行Java代碼的假象電腦,主要有一套位元組碼指令集,一組寄存器,一個棧,一個垃圾回收,堆 和 一個存儲方法域。
- 2.JVM運行在操作系統之上,與硬體沒有直接的交互。
Java程式執行過程:
- 1.編譯->源文件由編譯器編譯成位元組碼[ByteCode]
Java 源文件—->編譯器—->位元組碼文件
- 2.運行->位元組碼由java虛擬機解釋運行
位元組碼文件—->JVM—->機器碼
Java類的載入步驟:
- 1.載入->主要是完成3個階段的提交:
通過類的全限定名來獲取定義類的二進位位元組流
將位元組流所代表的靜態存儲結構轉化為方法區的運行時數據結構
在記憶體中生成一個代表這個類的java.lang.Class對象,作為方法區這個類的各種數據的訪問入口。
- 2.驗證->四個階段的檢驗動作:
文件格式驗證
元數據驗證
位元組碼驗證
符號引用驗證
- 3.準備->為類變數(static)分配記憶體並設置類變數的初始值。
- 4.解析->將常量池內的符號引用轉為直接的引用
- 5.初始化->按照static塊和static變數在文件中的出現順序,合併到
()方法中。實例變數由 ()函數賦值。
JVM線程實體:
JVM線程->程式執行過程中的一個線程實體,JVM 允許一個應用併發執行多個線程。
從此,我們應該意識到,在Java中,當提到線程就應該是指JVM線程和Java線程。其中JVM線程指的是Hotspot JVM 後臺運行的系統線程,而且Hotspot JVM 中的 Java 線程與原生操作系統線程有直接的映射關係。
⚠️[註意事項]:
[1].當線程本地存儲、緩衝區分配、同步對象、棧、程式計數器等準備好以後,就會創建一個操作系統原生線程。
[2].Java 線程結束,原生線程隨之被回收。操作系統負責調度所有線程,並把它們分配到任何可用的 CPU 上。
[3].當原生線程初始化完畢,就會調用 Java 線程的 run() 方法。當線程結束時,會釋放原生線程和 Java 線程的所有資源
特別需要知道的是,Hotspot JVM 後臺運行的系統線程主要是:
- 虛擬機線程->VM thread:等待 JVM 到達安全點操作出現。這些操作必須要在獨立的線程里執行,因為當堆修改無法進行時,線程都需要 JVM 位於安全點。這些操作的類型有:stop-theworld垃圾回收、線程棧 dump、線程暫停、線程偏向鎖(biased locking)解除。
- 周期性任務線程->負責定時器事件(也就是中斷),用來調度周期性操作的執行
- GC線程->支持 JVM 中不同的垃圾回收活動
- 編譯器線程->在運行時將位元組碼動態編譯成本地平臺相關的機器碼
- 信號分發線程->程接收發送到 JVM 的信號並調用適當的 JVM 方法處理
JVM記憶體
版權聲明:本文為博主原創文章,遵循相關版權協議,如若轉載或者分享請附上原文出處鏈接和鏈接來源。