自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

圖解JVM整體結(jié)構(gòu)、執(zhí)行流程以及兩種架構(gòu)模型,你學(xué)會了嗎?

云計算 虛擬化
Java 編譯器輸入的指令流基本上是一種基于棧的指令集架構(gòu),另外一種指令集架構(gòu)則是基于寄存器的指令集架構(gòu)。

[[431325]]

 JVM整體結(jié)構(gòu) 

圖解JVM整體結(jié)構(gòu)、執(zhí)行流程以及2種架構(gòu)模型,你學(xué)會了嗎? 
  • HotSpot VM 是目前市面上高性能虛擬機(jī)的代表作之一。
  • 方法區(qū)和堆:多線程共享
  • 虛擬機(jī)棧、本地方法棧、程序計數(shù)器:每個線程獨(dú)有一份
  • 執(zhí)行引擎:包含三部分:解釋器,及時編譯器(后端編譯器),垃圾回收器
  • 它采用解釋器與即時編譯器并存的架構(gòu)。
  • 在今天,Java 程序的運(yùn)行性能早已脫胎換骨,已經(jīng)達(dá)到了可以和 C/C++ 程序一較高下的地步。 
圖解JVM整體結(jié)構(gòu)、執(zhí)行流程以及2種架構(gòu)模型,你學(xué)會了嗎? 

Java 代碼執(zhí)行流程 

圖解JVM整體結(jié)構(gòu)、執(zhí)行流程以及2種架構(gòu)模型,你學(xué)會了嗎? 

只是能生成被 Java 虛擬機(jī)所能解釋的字節(jié)碼文件,那么理論上就可以自己設(shè)計一套代碼了

解釋器:保證相應(yīng)時間,負(fù)責(zé)解釋執(zhí)行的速度

JIT編譯器:負(fù)責(zé)編譯的性能,針對字節(jié)碼指令,熱點(diǎn)代碼,放在方法區(qū)緩存起來,下次遇見直接變成二進(jìn)制指令

JVM 的架構(gòu)模型

Java 編譯器輸入的指令流基本上是一種基于棧的指令集架構(gòu),另外一種指令集架構(gòu)則是基于寄存器的指令集架構(gòu)。

具體來說:這兩種架構(gòu)之間的區(qū)別:

基于棧式架構(gòu)

  • 設(shè)計和實(shí)現(xiàn)更簡單,適用于資源受限的系統(tǒng);
  • 避開了寄存器的分配難題:使用零地址指令方式分配。
  • 指令流中的指令大部分是零地址指令,其執(zhí)行過程依賴于操作棧。指令集更小,編譯器容易實(shí)現(xiàn)。
  • 不需要硬件支持,可移植性更好,更好實(shí)現(xiàn)跨平臺

基于寄存器架構(gòu)

  • 典型的應(yīng)用是 x86 的二進(jìn)制指令集:比如傳統(tǒng)的 PC 以及 Android 的 Davlik 虛擬機(jī)。
  • 指令集架構(gòu)則完全依賴硬件,可移植性差
  • 性能優(yōu)秀和執(zhí)行更高效
  • 花費(fèi)更少的指令去完成一項操作。
  • 在大部分情況下,基于寄存器架構(gòu)的指令集往往都以一地址指令、二地址指令和三地址指令為主,而基于棧式架構(gòu)的指令集卻是以零地址指令為主

舉例

同樣執(zhí)行2+3這種邏輯操作,其指令分別如下:

基于棧的計算流程(以Java虛擬機(jī)為例):

  1. iconst_2 // 常量2入棧 
  2. istore_1 
  3. iconst_3 // 常量3入棧 
  4. istore_2 
  5. iload_1 
  6. iload_2 
  7. iadd    //常量2/3出棧,執(zhí)行相加 
  8. istore_0 // 結(jié)果5入棧 

而基于寄存器的計算流程

  1. mov eax,2 //將eax寄存器的值設(shè)為 
  2. 1add eax,3 //使eax寄存器的值加3 

字節(jié)碼反編譯

我們編寫一個簡單的代碼,然后查看一下字節(jié)碼的反編譯后的結(jié)果

  1. public class StackStruTest { 
  2.   public static void main(String[] args) { 
  3.     int i = 2 + 3; 
  4.   } 

然后我們找到編譯后的 class 文件,使用下列命令進(jìn)行反編譯

  1. javap -v(verbose) StackStruTest.class 

得到的文件為:

  1. public static void main(java.lang.String[]); 
  2.     descriptor: ([Ljava/lang/String;)V 
  3.     flags: ACC_PUBLIC, ACC_STATIC 
  4.     Code: 
  5.       stack=2, locals=4, args_size=1 
  6.          0: iconst_2 
  7.          1: istore_1 
  8.          2: iconst_3 
  9.          3: istore_2 
  10.          4: iload_1 
  11.          5: iload_2 
  12.          6: iadd 
  13.          7: istore_3 
  14.          8: return 
  15.       LineNumberTable: 
  16.         line 9: 0 
  17.         line 10: 2 
  18.         line 11: 4 
  19.         line 12: 8 
  20.       LocalVariableTable: 
  21.         Start  Length  Slot  Name   Signature 
  22.             0       9     0  args   [Ljava/lang/String; 
  23.             2       7     1     i   I 
  24.             4       5     2     j   I 
  25.             8       1     3     k   I 
  26.   

總結(jié)

由于跨平臺性的設(shè)計,Java 的指令都是根據(jù)棧來設(shè)計的。

不同平臺 CPU 架構(gòu)不同,所以不能設(shè)計為基于寄存器的。

優(yōu)點(diǎn)是跨平臺,指令集小,編譯器容易實(shí)現(xiàn)

缺點(diǎn)是性能下降,實(shí)現(xiàn)同樣的功能需要更多的指令。

時至今日,盡管嵌入式平臺已經(jīng)不是 Java 程序的主流運(yùn)行平臺了(準(zhǔn)確來說應(yīng)該是 HotSpotVM 的宿主環(huán)境已經(jīng)不局限于嵌入式平臺了),那么為什么不將架構(gòu)更換為基于寄存器的架構(gòu)呢?

總結(jié):因為已經(jīng)夠用了

跨平臺性

指令集小

指令多

執(zhí)行性能比寄存器差

 

責(zé)任編輯:武曉燕 來源: 今日頭條
相關(guān)推薦

2025-01-16 08:38:34

2023-08-28 07:02:10

2023-05-29 07:43:32

JVM內(nèi)存調(diào)優(yōu)

2023-07-31 07:33:05

JVM調(diào)優(yōu)Full GC

2023-05-05 08:29:15

Spring后臺服務(wù)器

2024-11-13 11:12:08

JVM內(nèi)存區(qū)域

2011-06-15 13:07:10

JSP和JavaBea

2024-09-27 10:27:50

2023-01-10 08:43:15

定義DDD架構(gòu)

2024-02-04 00:00:00

Effect數(shù)據(jù)組件

2023-07-26 13:11:21

ChatGPT平臺工具

2024-01-19 08:25:38

死鎖Java通信

2024-01-02 12:05:26

Java并發(fā)編程

2023-08-01 12:51:18

WebGPT機(jī)器學(xué)習(xí)模型

2022-06-04 07:46:41

HeapJVM

2023-12-27 09:32:47

SQL語句數(shù)據(jù)

2021-07-01 19:22:33

腳本Shell參數(shù)

2024-01-30 18:29:29

微服務(wù)架構(gòu)Ingress

2024-09-09 09:00:12

架構(gòu)設(shè)計算法

2024-01-26 08:24:16

Dalvik架構(gòu)ART
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號