0x00 |
nop |
什麼都不作 |
0x01 |
aconst_null |
將 null 推送至棧頂 |
0x02 |
iconst_m1 |
將 int 型 -1 推送至棧頂 |
0x03 |
iconst_0 |
將 int 型 0 推送至棧頂 |
0x04 |
iconst_1 |
將 int 型 1 推送至棧頂 |
0x05 |
iconst_2 |
將 int 型 2 推送至棧頂 |
0x06 |
iconst_3 |
將 int 型 3 推送至棧頂 |
0x07 |
iconst_4 |
將 int 型 4 推送至棧頂 |
0x08 |
iconst_5 |
將 int 型 5 推送至棧頂 |
0x09 |
lconst_0 |
將 long 型 0 推送至棧頂 |
0x0a |
lconst_1 |
將 long 型 1 推送至棧頂 |
0x0b |
fconst_0 |
將 float 型 0 推送至棧頂 |
0x0c |
fconst_1 |
將 float 型 1 推送至棧頂 |
0x0d |
fconst_2 |
將 float 型 2 推送至棧頂 |
0x0e |
dconst_0 |
將 double 型 0 推送至棧頂 |
0x0f |
dconst_1 |
將 double 型 1 推送至棧頂 |
0x10 |
bipush |
將單字節的常量值(Byte.MIN_VALUE ~ Byte.MAX_VALUE,即 -128~127)推送至棧頂 |
0x11 |
sipush |
將短整型的常量值(Short.MIN_VALUE ~ Short.MAX_VALUE,即 -32768~32767)推送至棧頂 |
0x12 |
ldc |
將 int、float 或 String 型常量值從常量池中推送至棧頂 |
0x13 |
ldc_w |
將 int、float 或 String 型常量值從常量池中推送至棧頂(寬索引) |
0x14 |
ldc2_w |
將 long 或 double 型常量值從常量池中推送至棧頂(寬索引) |
0x15 |
iload |
將指定的 int 型局部變量推送至棧頂 |
0x16 |
lload |
將指定的 long 型局部變量推送至棧頂 |
0x17 |
fload |
將指定的 float 型局部變量推送至棧頂 |
0x18 |
dload |
將指定的 double 型局部變量推送至棧頂 |
0x19 |
aload |
將指定的 引用 型局部變量推送至棧頂 |
0x1a |
iload_0 |
將第一個 int 型局部變量推送至棧頂 |
0x1b |
iload_1 |
將第二個 int 型局部變量推送至棧頂 |
0x1c |
iload_2 |
將第三個 int 型局部變量推送至棧頂 |
0x1d |
iload_3 |
將第四個 int 型局部變量推送至棧頂 |
0x1e |
lload_0 |
將第一個 long 型局部變量推送至棧頂 |
0x1f |
lload_1 |
將第二個 long 型局部變量推送至棧頂 |
0x20 |
lload_2 |
將第三個 long 型局部變量推送至棧頂 |
0x21 |
lload_3 |
將第四個 long 型局部變量推送至棧頂 |
0x22 |
fload_0 |
將第一個 float 型局部變量推送至棧頂 |
0x23 |
fload_1 |
將第二個 float 型局部變量推送至棧頂 |
0x24 |
fload_2 |
將第三個 float 型局部變量推送至棧頂 |
0x25 |
fload_3 |
將第四個 float 型局部變量推送至棧頂 |
0x26 |
dload_0 |
將第一個 double 型局部變量推送至棧頂 |
0x27 |
dload_1 |
將第二個 double 型局部變量推送至棧頂 |
0x28 |
dload_2 |
將第三個 double 型局部變量推送至棧頂 |
0x29 |
dload_3 |
將第四個 double 型局部變量推送至棧頂 |
0x2a |
aload_0 |
將第一個 引用 型局部變量推送至棧頂 |
0x2b |
aload_1 |
將第二個 引用 型局部變量推送至棧頂 |
0x2c |
aload_2 |
將第三個 引用 型局部變量推送至棧頂 |
0x2d |
aload_3 |
將第四個 引用 型局部變量推送至棧頂 |
0x2e |
iaload |
將 int 型數組指定索引的值推送至棧頂 |
0x2f |
laload |
將 long 型數組指定索引的值推送至棧頂 |
0x30 |
faload |
將 float 型數組指定索引的值推送至棧頂 |
0x31 |
daload |
將 double 型數組指定索引的值推送至棧頂 |
0x32 |
aaload |
將 引用 型數組指定索引的值推送至棧頂 |
0x33 |
baload |
將 boolean 或 byte 型數組指定索引的值推送至棧頂 |
0x34 |
caload |
將 char 型數組指定索引的值推送至棧頂 |
0x35 |
saload |
將 short 型數組指定索引的值推送至棧頂 |
0x36 |
istore |
將棧頂 int 型數值存入指定局部變量 |
0x37 |
lstore |
將棧頂 long 型數值存入指定局部變量 |
0x38 |
fstore |
將棧頂 float 型數值存入指定局部變量 |
0x39 |
dstore |
將棧頂 double 型數值存入指定局部變量 |
0x3a |
astore |
將棧頂 引用 型數值存入指定局部變量 |
0x3b |
istore_0 |
將棧頂 int 型數值存入第一個局部變量 |
0x3c |
istore_1 |
將棧頂 int 型數值存入第二個局部變量 |
0x3d |
istore_2 |
將棧頂 int 型數值存入第三個局部變量 |
0x3e |
istore_3 |
將棧頂 int 型數值存入第四個局部變量 |
0x3f |
lstore_0 |
將棧頂 long 型數值存入第一個局部變量 |
0x40 |
lstore_1 |
將棧頂 long 型數值存入第二個局部變量 |
0x41 |
lstore_2 |
將棧頂 long 型數值存入第三個局部變量 |
0x42 |
lstore_3 |
將棧頂 long 型數值存入第四個局部變量 |
0x43 |
fstore_0 |
將棧頂 float 型數值存入第一個局部變量 |
0x44 |
fstore_1 |
將棧頂 float 型數值存入第二個局部變量 |
0x45 |
fstore_2 |
將棧頂 float 型數值存入第三個局部變量 |
0x46 |
fstore_3 |
將棧頂 float 型數值存入第四個局部變量 |
0x47 |
dstore_0 |
將棧頂 double 型數值存入第一個局部變量 |
0x48 |
dstore_1 |
將棧頂 double 型數值存入第二個局部變量 |
0x49 |
dstore_2 |
將棧頂 double 型數值存入第三個局部變量 |
0x4a |
dstore_3 |
將棧頂 double 型數值存入第四個局部變量 |
0x4b |
astore_0 |
將棧頂 引用 型數值存入第一個局部變量 |
0x4c |
astore_1 |
將棧頂 引用 型數值存入第二個局部變量 |
0x4d |
astore_2 |
將棧頂 引用 型數值存入第三個局部變量 |
0x4e |
astore_3 |
將棧頂 引用 型數值存入第四個局部變量 |
0x4f |
iastore |
將棧頂 int 型數值存入指定數組的指定索引位置 |
0x50 |
lastore |
將棧頂 long 型數值存入指定數組的指定索引位置 |
0x51 |
fastore |
將棧頂 float 型數值存入指定數組的指定索引位置 |
0x52 |
dastore |
將棧頂 double 型數值存入指定數組的指定索引位置 |
0x53 |
aastore |
將棧頂 引用 型數值存入指定數組的指定索引位置 |
0x54 |
bastore |
將棧頂 boolean 或 byte 型數值存入指定數組的指定索引位置 |
0x55 |
castore |
將棧頂 char 型數值存入指定數組的指定索引位置 |
0x56 |
sastore |
將棧頂 short 型數值存入指定數組的指定索引位置 |
0x57 |
pop |
將棧頂數值彈出(數值不能是 long 或 double 類型的) |
0x58 |
pop2 |
將棧頂的一個(對於 long 或 double 類型)或兩個數值(對於非 long 或 double 的其餘類型)彈出 |
0x59 |
dup |
複製棧頂數值並將複製值壓入棧頂 |
0x5a |
dup_x1 |
複製棧頂數值並將兩個複製值壓入棧頂 |
0x5b |
dup_x2 |
複製棧頂數值並將三個(或兩個)複製值壓入棧頂 |
0x5c |
dup2 |
複製棧頂一個(對於 long 或 double 類型)或兩個數值(對於非 long 或 double 的其餘類型)並將複製值壓入棧頂 |
0x5d |
dup2_x1 |
dup_x1 指令的雙倍版本 |
0x5e |
dup2_x2 |
dup_x2 指令的雙倍版本 |
0x5f |
swap |
將棧最頂端的兩個數值互換(數值不能是 long 或 double 類型) |
0x60 |
iadd |
將棧頂兩 int 型數值相加並將結果壓入棧頂 |
0x61 |
ladd |
將棧頂兩 long 型數值相加並將結果壓入棧頂 |
0x62 |
fadd |
將棧頂兩 float 型數值相加並將結果壓入棧頂 |
0x63 |
dadd |
將棧頂兩 double 型數值相加並將結果壓入棧頂 |
0x64 |
isub |
將棧頂兩 int 型數值相減並將結果壓入棧頂 |
0x65 |
lsub |
將棧頂兩 long 型數值相減並將結果壓入棧頂 |
0x66 |
fsub |
將棧頂兩 float 型數值相減並將結果壓入棧頂 |
0x67 |
dsub |
將棧頂兩 double 型數值相減並將結果壓入棧頂 |
0x68 |
imul |
將棧頂兩 int 型數值相乘並將結果壓入棧頂 |
0x69 |
lmul |
將棧頂兩 long 型數值相乘並將結果壓入棧頂 |
0x6a |
fmul |
將棧頂兩 float 型數值相乘並將結果壓入棧頂 |
0x6b |
dmul |
將棧頂兩 double 型數值相乘並將結果壓入棧頂 |
0x6c |
idiv |
將棧頂兩 int 型數值相除並將結果壓入棧頂 |
0x6d |
ldiv |
將棧頂兩 long 型數值相除並將結果壓入棧頂 |
0x6e |
fdiv |
將棧頂兩 float 型數值相除並將結果壓入棧頂 |
0x6f |
ddiv |
將棧頂兩 double 型數值相除並將結果壓入棧頂 |
0x70 |
irem |
將棧頂兩 int 型數值做取模運算並將結果壓入棧頂 |
0x71 |
lrem |
將棧頂兩 long 型數值做取模運算並將結果壓入棧頂 |
0x72 |
frem |
將棧頂兩 float 型數值做取模運算並將結果壓入棧頂 |
0x73 |
drem |
將棧頂兩 double 型數值做取模運算並將結果壓入棧頂 |
0x74 |
ineg |
將棧頂兩 int 型數值取負並將結果壓入棧頂 |
0x75 |
lneg |
將棧頂兩 long 型數值取負並將結果壓入棧頂 |
0x76 |
fneg |
將棧頂兩 float 型數值取負並將結果壓入棧頂 |
0x77 |
dneg |
將棧頂兩 double 型數值取負並將結果壓入棧頂 |
0x78 |
ishl |
將 int 型數值左移指定位數並將結果壓入棧頂 |
0x79 |
lshl |
將 long 型數值左移指定位數並將結果壓入棧頂 |
0x7a |
ishr |
將 int 型數值右(帶符號)移指定位數並將結果壓入棧頂 |
0x7b |
lshr |
將 long 型數值右(帶符號)移指定位數並將結果壓入棧頂 |
0x7c |
iushr |
將 int 型數值右(無符號)移指定位數並將結果壓入棧頂 |
0x7d |
lushr |
將 long 型數值右(無符號)移指定位數並將結果壓入棧頂 |
0x7e |
iand |
將棧頂兩 int 型數值做「按位與」並將結果壓入棧頂 |
0x7f |
land |
將棧頂兩 long 型數值做「按位與」並將結果壓入棧頂 |
0x80 |
ior |
將棧頂兩 int 型數值做「按位或」並將結果壓入棧頂 |
0x81 |
lor |
將棧頂兩 long 型數值做「按位或」並將結果壓入棧頂 |
0x82 |
ixor |
將棧頂兩 int 型數值做「按位異或」並將結果壓入棧頂 |
0x83 |
lxor |
將棧頂兩 long 型數值做「按位異或」並將結果壓入棧頂 |
0x84 |
iinc M N |
(M 爲非負整數,N 爲整數)將局部變量數組的第 M 個單元中的 int 值增長 N,經常使用於 for 循環中自增量的更新 |
0x85 |
i2l |
將棧頂 int 型數值強制轉換成 long 型數值,並將結果壓入棧頂 |
0x86 |
i2f |
將棧頂 int 型數值強制轉換成 float 型數值,並將結果壓入棧頂 |
0x87 |
i2d |
將棧頂 int 型數值強制轉換成 double 型數值,並將結果壓入棧頂 |
0x88 |
l2i |
將棧頂 long 型數值強制轉換成 int 型數值,並將結果壓入棧頂 |
0x89 |
l2f |
將棧頂 long 型數值強制轉換成 float 型數值,並將結果壓入棧頂 |
0x8a |
l2d |
將棧頂 long 型數值強制轉換成 double 型數值,並將結果壓入棧頂 |
0x8b |
f2i |
將棧頂 float 型數值強制轉換成 int 型數值,並將結果壓入棧頂 |
0x8c |
f2l |
將棧頂 float 型數值強制轉換成 long 型數值,並將結果壓入棧頂 |
0x8d |
f2d |
將棧頂 float 型數值強制轉換成 double 型數值,並將結果壓入棧頂 |
0x8e |
d2i |
將棧頂 double 型數值強制轉換成 int 型數值,並將結果壓入棧頂 |
0x8f |
d2l |
將棧頂 double 型數值強制轉換成 long 型數值,並將結果壓入棧頂 |
0x90 |
d2f |
將棧頂 double 型數值強制轉換成 float 型數值,並將結果壓入棧頂 |
0x91 |
i2b |
將棧頂 int 型數值強制轉換成 byte 型數值,並將結果壓入棧頂 |
0x92 |
i2c |
將棧頂 int 型數值強制轉換成 char 型數值,並將結果壓入棧頂 |
0x93 |
i2s |
將棧頂 int 型數值強制轉換成 short 型數值,並將結果壓入棧頂 |
0x94 |
lcmp |
比較棧頂兩 long 型數值的大小,並將結果(一、0 或 -1)壓入棧頂 |
0x95 |
fcmpl |
比較棧頂兩 float 型數值的大小,並將結果(一、0 或 -1)壓入棧頂 ;當其中一個數值爲 「NaN」 時,將 -1 壓入棧頂 |
0x96 |
fcmpg |
比較棧頂兩 float 型數值的大小,並將結果(一、0 或 -1)壓入棧頂 ;當其中一個數值爲 「NaN」 時,將 1 壓入棧頂 |
0x97 |
dcmpl |
比較棧頂兩 double 型數值的大小,並將結果(一、0 或 -1)壓入棧頂 ;當其中一個數值爲 「NaN」 時,將 -1 壓入棧頂 |
0x98 |
dcmpg |
比較棧頂兩 double 型數值的大小,並將結果(一、0 或 -1)壓入棧頂 ;當其中一個數值爲 「NaN」 時,將 1 壓入棧頂 |
0x99 |
ifeq |
當棧頂 int 型數值等於 0 時跳轉 |
0x9a |
ifne |
當棧頂 int 型數值不等於 0 時跳轉 |
0x9b |
iflt |
當棧頂 int 型數值小於 0 時跳轉 |
0x9c |
ifge |
當棧頂 int 型數值大於或等於 0 時跳轉 |
0x9d |
ifgt |
當棧頂 int 型數值大於 0 時跳轉 |
0x9e |
ifle |
當棧頂 int 型數值小於或等於 0 時跳轉 |
0x9f |
if_icmpeq |
比較棧頂兩 int 型數值的大小,當結果等於 0 時跳轉 |
0xa0 |
if_icmpne |
比較棧頂兩 int 型數值的大小,當結果不等於 0 時跳轉 |
0xa1 |
if_icmplt |
比較棧頂兩 int 型數值的大小,當結果小於 0 時跳轉 |
0xa2 |
if_icmpge |
比較棧頂兩 int 型數值的大小,當結果大於或等於 0 時跳轉 |
0xa3 |
if_icmpgt |
比較棧頂兩 int 型數值的大小,當結果大於 0 時跳轉 |
0xa4 |
if_icmple |
比較棧頂兩 int 型數值的大小,當結果小於或等於 0 時跳轉 |
0xa5 |
if_acmpeq |
比較棧頂兩 引用 型數值,當結果相等時跳轉 |
0xa6 |
if_acmpne |
比較棧頂兩 引用 型數值,當結果不相等時跳轉 |
0xa7 |
goto |
無條件跳轉 |
0xa8 |
jsr |
跳轉至指定的 16 位 offset 位置,並將 jsr 的下一條指令地址壓入棧頂 |
0xa9 |
ret |
返回至局部變量指定的 index 的指令位置(通常與 jsr 或 jsr_w 聯合使用) |
0xaa |
tableswitch |
用於 switch 條件跳轉,case 值連續(可變長度指令) |
0xab |
lookupswitch |
用於 switch 條件跳轉,case 值不連續(可變長度指令) |
0xac |
ireturn |
從當前方法返回 int |
0xad |
lreturn |
從當前方法返回 long |
0xae |
freturn |
從當前方法返回 float |
0xaf |
dreturn |
從當前方法返回 double |
0xb0 |
areturn |
從當前方法返回對象引用 |
0xb1 |
return |
從當前方法返回 void |
0xb2 |
getstatic |
獲取指定類的靜態字段,並將其壓入棧頂 |
0xb3 |
putstatic |
爲指定類的靜態字段賦值 |
0xb4 |
getfield |
獲取指定類的實例字段,並將其壓入棧頂 |
0xb5 |
putfield |
爲指定類的實例字段賦值 |
0xb6 |
invokevirtual |
調用實例方法 |
0xb7 |
invokespecial |
調用超類構造方法,實例初始化方法,私有方法 |
0xb8 |
invokestatic |
調用靜態方法 |
0xb9 |
invokeinterface |
調用接口方法 |
0xba |
-- |
無此指令 |
0xbb |
new |
建立一個對象,並將其引用值壓入棧頂 |
0xbc |
newarray |
建立一個指定的原始類型(如 int、float、char 等)的數組,並將其引用值壓入棧頂 |
0xbd |
anewarray |
建立一個引用型(如類、接口、數組 等)的數組,並將其引用值壓入棧頂 |
0xbe |
arraylength |
得到數組的長度值並將其壓入棧頂 |
0xbf |
athrow |
將棧頂的異常拋出 |
0xc0 |
checkcast |
校驗類型轉換,校驗未經過將拋出 ClassCastException |
0xc1 |
instanceof |
校驗對象是不是指定的類的實例,若是是則將 1 壓入棧頂,不然將 0 壓入棧頂 |
0xc2 |
monitorenter |
得到對象的鎖,用於同步方法或同步塊 |
0xc3 |
monitorexit |
釋放對象的鎖,用於同步方法或同步塊 |
0xc4 |
wide |
擴展局部變量的寬度 |
0xc5 |
multianewarray |
建立指定類型和指定維度的多維數組(執行該指定時,操做數棧中必須包含各維度的長度),並將其引用值壓入棧頂 |
0xc6 |
ifnull |
爲 null 時跳轉 |
0xc7 |
ifnonnull |
不爲 null 時跳轉 |
0xc8 |
goto_w |
無條件跳轉(寬索引) |
0xc9 |
jsr_w |
跳轉至指定的 32 位 offset 位置,並將 jsr_w 的下一條指令地址壓入棧頂 |