Java位元組碼指令
Java位元組碼指令
Java 位元組碼指令及javap 使用說明
### java位元組碼指令列表
位元組碼 | 助記符 | 指令含義 |
---|---|---|
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 | 將do le型0推送至棧頂 |
0x0f | dconst_1 | 將do le型1推送至棧頂 |
0x10 | bipush | 將單位元組的常量值(-128~127)推送至棧頂 |
0x11 | sipush | 將一個短整型常量值(-32768~32767)推送至棧頂 |
0x12 | ldc | 將int, float或String型常量值從常量池中推送至棧頂 |
0x13 | ldc_w | 將int, float或String型常量值從常量池中推送至棧頂(寬索引) |
0x14 | ldc2_w | 將long或do le型常量值從常量池中推送至棧頂(寬索引) |
0x15 | iload | 將指定的int型本地變數 |
0x16 | lload | 將指定的long型本地變數 |
0x17 | fload | 將指定的float型本地變數 |
0x18 | dload | 將指定的do le型本地變數 |
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 | 將第一個do le型本地變數 |
0x27 | dload_1 | 將第二個do le型本地變數 |
0x28 | dload_2 | 將第三個do le型本地變數 |
0x29 | dload_3 | 將第四個do le型本地變數 |
0x2a | aload_0 | 將第一個引用型別本地變數 |
0x2b | aload_1 | 將第二個引用型別本地變數 |
0x2c | aload_2 | 將第三個引用型別本地變數 |
0x2d | aload_3 | 將第四個引用型別本地變數 |
0x2e | iaload | 將int型陣列指定索引的值推送至棧頂 |
0x2f | laload | 將long型陣列指定索引的值推送至棧頂 |
0x30 | faload | 將float型陣列指定索引的值推送至棧頂 |
0x31 | daload | 將do le型陣列指定索引的值推送至棧頂 |
0x32 | aaload | 將引用型陣列指定索引的值推送至棧頂 |
0x33 | baload | 將boolean或byte型陣列指定索引的值推送至棧頂 |
0x34 | caload | 將char型陣列指定索引的值推送至棧頂 |
0x35 | saload | 將short型陣列指定索引的值推送至棧頂 |
0x36 | istore | 將棧頂int型數值存入指定本地變數 |
0x37 | lstore | 將棧頂long型數值存入指定本地變數 |
0x38 | fstore | 將棧頂float型數值存入指定本地變數 |
0x39 | dstore | 將棧頂do le型數值存入指定本地變數 |
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 | 將棧頂do le型數值存入第一個本地變數 |
0x48 | dstore_1 | 將棧頂do le型數值存入第二個本地變數 |
0x49 | dstore_2 | 將棧頂do le型數值存入第三個本地變數 |
0x4a | dstore_3 | 將棧頂do le型數值存入第四個本地變數 |
0x4b | astore_0 | 將棧頂引用型數值存入第一個本地變數 |
0x4c | astore_1 | 將棧頂引用型數值存入第二個本地變數 |
0x4d | astore_2 | 將棧頂引用型數值存入第三個本地變數 |
0x4e | astore_3 | 將棧頂引用型數值存入第四個本地變數 |
0x4f | iastore | 將棧頂int型數值存入指定陣列的指定索引位置 |
0x50 | lastore | 將棧頂long型數值存入指定陣列的指定索引位置 |
0x51 | fastore | 將棧頂float型數值存入指定陣列的指定索引位置 |
0x52 | dastore | 將棧頂do le型數值存入指定陣列的指定索引位置 |
0x53 | aastore | 將棧頂引用型數值存入指定陣列的指定索引位置 |
0x54 | bastore | 將棧頂boolean或byte型數值存入指定陣列的指定索引位置 |
0x55 | castore | 將棧頂char型數值存入指定陣列的指定索引位置 |
0x56 | sastore | 將棧頂short型數值存入指定陣列的指定索引位置 |
0x57 | pop | 將棧頂數值彈出 (數值不能是long或do le型別的) |
0x58 | pop2 | 將棧頂的一個(long或do le型別的)或兩個數值彈出(其它) |
0x59 | dup | 複製棧頂數值並將複製值壓入棧頂 |
0x5a | dup_x1 | 複製棧頂數值並將兩個複製值壓入棧頂 |
0x5b | dup_x2 | 複製棧頂數值並將三個(或兩個)複製值壓入棧頂 |
0x5c | dup2 | 複製棧頂一個(long或do le型別的)或兩個(其它)數值並將複製值壓入棧頂 |
0x5d | dup2_x1 | dup_x1 指令的雙倍版本 |
0x5e | dup2_x2 | dup_x2 指令的雙倍版本 |
0x5f | swap | 將棧最頂端的兩個數值互換(數值不能是long或do le型別的) |
0x60 | iadd | 將棧頂兩int型數值相加並將結果壓入棧頂 |
0x61 | ladd | 將棧頂兩long型數值相加並將結果壓入棧頂 |
0x62 | fadd | 將棧頂兩float型數值相加並將結果壓入棧頂 |
0x63 | dadd | 將棧頂兩do le型數值相加並將結果壓入棧頂 |
0x64 | is | 將棧頂兩int型數值相減並將結果壓入棧頂 |
0x65 | ls | 將棧頂兩long型數值相減並將結果壓入棧頂 |
0x66 | fs | 將棧頂兩float型數值相減並將結果壓入棧頂 |
0x67 | ds | 將棧頂兩do le型數值相減並將結果壓入棧頂 |
0x68 | imul | 將棧頂兩int型數值相乘並將結果壓入棧頂 |
0x69 | lmul | 將棧頂兩long型數值相乘並將結果壓入棧頂 |
0x6a | fmul | 將棧頂兩float型數值相乘並將結果壓入棧頂 |
0x6b | dmul | 將棧頂兩do le型數值相乘並將結果壓入棧頂 |
0x6c | idiv | 將棧頂兩int型數值相除並將結果壓入棧頂 |
0x6d | ldiv | 將棧頂兩long型數值相除並將結果壓入棧頂 |
0x6e | fdiv | 將棧頂兩float型數值相除並將結果壓入棧頂 |
0x6f | ddiv | 將棧頂兩do le型數值相除並將結果壓入棧頂 |
0x70 | irem | 將棧頂兩int型數值作取模運算並將結果壓入棧頂 |
0x71 | lrem | 將棧頂兩long型數值作取模運算並將結果壓入棧頂 |
0x72 | frem | 將棧頂兩float型數值作取模運算並將結果壓入棧頂 |
0x73 | drem | 將棧頂兩do le型數值作取模運算並將結果壓入棧頂 |
0x74 | ineg | 將棧頂int型數值取負並將結果壓入棧頂 |
0x75 | lneg | 將棧頂long型數值取負並將結果壓入棧頂 |
0x76 | fneg | 將棧頂float型數值取負並將結果壓入棧頂 |
0x77 | dneg | 將棧頂do le型數值取負並將結果壓入棧頂 |
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 | 將指定int型變數增加指定值(i++, i–, i+=2) |
0x85 | i2l | 將棧頂int型數值強制轉換成long型數值並將結果壓入棧頂 |
0x86 | i2f | 將棧頂int型數值強制轉換成float型數值並將結果壓入棧頂 |
0x87 | i2d | 將棧頂int型數值強制轉換成do le型數值並將結果壓入棧頂 |
0x88 | l2i | 將棧頂long型數值強制轉換成int型數值並將結果壓入棧頂 |
0x89 | l2f | 將棧頂long型數值強制轉換成float型數值並將結果壓入棧頂 |
0x8a | l2d | 將棧頂long型數值強制轉換成do le型數值並將結果壓入棧頂 |
0x8b | f2i | 將棧頂float型數值強制轉換成int型數值並將結果壓入棧頂 |
0x8c | f2l | 將棧頂float型數值強制轉換成long型數值並將結果壓入棧頂 |
0x8d | f2d | 將棧頂float型數值強制轉換成do le型數值並將結果壓入棧頂 |
0x8e | d2i | 將棧頂do le型數值強制轉換成int型數值並將結果壓入棧頂 |
0x8f | d2l | 將棧頂do le型數值強制轉換成long型數值並將結果壓入棧頂 |
0x90 | d2f | 將棧頂do le型數值強制轉換成float型數值並將結果壓入棧頂 |
0x91 | i2b | 將棧頂int型數值強制轉換成byte型數值並將結果壓入棧頂 |
0x92 | i2c | 將棧頂int型數值強制轉換成char型數值並將結果壓入棧頂 |
0x93 | i2s | 將棧頂int型數值強制轉換成short型數值並將結果壓入棧頂 |
0x94 | lcmp | 比較棧頂兩long型數值大小,並將結果(1,0,-1)壓入棧頂 |
0x95 | fcmpl | 比較棧頂兩float型數值大小,並將結果(1,0,-1)壓入棧頂;當其中一個數值為NaN時,將-1壓入棧頂 |
0x96 | fcmpg | 比較棧頂兩float型數值大小,並將結果(1,0,-1)壓入棧頂;當其中一個數值為NaN時,將1壓入棧頂 |
0x97 | dcmpl | 比較棧頂兩do le型數值大小,並將結果(1,0,-1)壓入棧頂;當其中一個數值為NaN時,將-1壓入棧頂 |
0x98 | dcmpg | 比較棧頂兩do le型數值大小,並將結果(1,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 | 返回至本地變數 |
0xaa | tableswitch | 用於switch條件跳轉,case值連續(可變長度指令) |
0xab | lookupswitch | 用於switch條件跳轉,case值不連續(可變長度指令) |
0xac | ireturn | 從當前方法返回int |
0xad | lreturn | 從當前方法返回long |
0xae | freturn | 從當前方法返回float |
0xaf | dreturn | 從當前方法返回do le |
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下一條指令地址壓入棧頂 |
JVM指令助記符
變數到運算元棧:iload,iload_,lload,lload_,fload,fload_,dload,dload_,aload,aload_
運算元棧到變數:istore,istore_,lstore,lstore_,fstore,fstore_,dstore,dstor_,astore,astore_
常數到運算元棧:bipush,sipush,ldc,ldc_w,ldc2_w,aconst_null,iconst_ml,iconst_,lconst_,fconst_,dconst_
加:iadd,ladd,fadd,dadd
減:is ,ls ,fs ,ds
乘:imul,lmul,fmul,dmul
除:idiv,ldiv,fdiv,ddiv
餘數:irem,lrem,frem,drem
取負:ineg,lneg,fneg,dneg
移位:ishl,lshr,iushr,lshl,lshr,lushr
按位或:ior,lor
按位與:iand,land
按位異或:ixor,lxor
型別轉換:i2l,i2f,i2d,l2f,l2d,f2d(放寬數值轉換)
i2b,i2c,i2s,l2i,f2i,f2l,d2i,d2l,d2f(縮窄數值轉換)
建立類實便:new
建立新陣列:newarray,anewarray,multianwarray
訪問類的域和類例項域:getfield,putfield,getstatic,putstatic
把資料裝載到運算元棧:baload,caload,saload,iaload,laload,faload,daload,aaload
從運算元棧存儲存到陣列:bastore,castore,sastore,iastore,lastore,fastore,dastore,aastore
獲取陣列長度:arraylength
檢相類例項或陣列屬性:instanceof,checkcast
運算元棧管理:pop,pop2,dup,dup2,dup_xl,dup2_xl,dup_x2,dup2_x2,swap
有條件轉移:ifeq,iflt,ifle,ifne,ifgt,ifge,ifnull,ifnonnull,if_icmpeq,if_icmpene,
if_icmplt,if_icmpgt,if_icmple,if_icmpge,if_acmpeq,if_acmpne,lcmp,fcmpl
fcmpg,dcmpl,dcmpg
複合條件轉移:tableswitch,lookupswitch
無條件轉移:goto,goto_w,jsr,jsr_w,ret
排程物件的實便方法:invokevirt l
呼叫由介面實現的方法:invokeinterface
呼叫需要特殊處理的例項方法:invokespecial
呼叫命名類中的靜態方法:invokestatic
方法返回:ireturn,lreturn,freturn,dreturn,areturn,return
異常:athrow
finally關鍵字的實現使用:jsr,jsr_w,ret
javap
-help
Prints out help message for javap.
-l
Prints out line and local variable tables.
-b
Ensures backward compatibility with javap in JDK 1.1.
-p lic
Shows only p lic classes and members.
-protected
Shows only protected and p lic classes and members.
-package
Shows only package, protected, and p lic classes and members. This is the default.
-private
Shows all classes and members.
-Jflag
Pass flag directly to the runtime system. Some examples:
javap -J-version
javap -J-Djava.security.manager -J-Djava.security.policy=MyPolicy MyClassName
-s
Prints internal type signatures.
-c
Prints out disassembled code, i.e., the instr tions that comprise the Java bytecodes, for each of the methods in the class. These are documented in the Java Virt l Machine Specification.
-verbose
Prints stack size, number of locals and args for methods.
-classpath path
Specifies the path javap uses to look up classes. Overrides the default or the CLASSPATH environment variable if it is set. Directories are separated by semi-colons. Thus the general format for path is:
.;
For example:
.;C:\usrs\dac\classes;C:\tools\java\classes
-bootclasspath path
Specifies path from which to load bootstrap classes. By default, the bootstrap classes are the classes implementing the core Java platform located in jre\lib\rt.jar and several other jar files.
-extdirs dirs
相關文章
- Java位元組碼指令表Java
- 位元組碼指令
- Java 位元組碼Java
- JAVA動態位元組碼Java
- 【Java】JVM位元組碼分析JavaJVM
- Class檔案結構&位元組碼指令
- 位元組碼指令分析 ++i 和 i++
- 輕鬆看懂Java位元組碼Java
- Java位元組碼忍者禁術Java
- Java的魔力:位元組碼(轉)Java
- 深入理解JAVA虛擬機器學習筆記18——位元組碼指令2(運算指令)Java虛擬機機器學習筆記
- 硬核萬字長文,深入理解 Java 位元組碼指令(建議收藏)Java
- JVMClass詳解之二Method位元組碼指令JVM
- 例項分析理解Java位元組碼Java
- Java位元組碼增強技術Java
- cmd下檢視java位元組碼Java
- 如何閱讀JAVA 位元組碼(一)Java
- 【JVM原始碼解析】模板直譯器解釋執行Java位元組碼指令(上)JVM原始碼Java
- jvm 虛擬機器位元組碼指令表JVM虛擬機
- 深入淺出JVM(十)之位元組碼指令(下篇)JVM
- Java 動態性(4) – 位元組碼操作Java
- 從 Java 位元組碼到 ASM 實踐JavaASM
- 學習 Java 之 位元組碼驗證Java
- JVM(三):深入分析Java位元組碼-上JVMJava
- JVM(四):深入分析Java位元組碼-下JVMJava
- JWebAssembly:Java 位元組碼到 WebAssembly 編譯器WebJava編譯
- Dalvik 和 Java 位元組碼的比較Java
- Java程式碼如何檢視位元組碼及彙編碼Java
- [深入理解Java虛擬機器]第六章 位元組碼指令簡介Java虛擬機
- ASM位元組碼操作類庫(開啟java語言世界通往位元組碼世界的大門)ASMJava
- ASM位元組碼操作類庫:開啟java語言世界通往位元組碼世界的大門ASMJava
- 開啟java語言世界通往位元組碼世界的大門——ASM位元組碼操作類庫JavaASM
- 位元組碼基礎
- 位元組碼詳解
- java 位元組陣列取反Java陣列
- 從1+1=2來理解Java位元組碼Java
- 使用javap分析Java位元組碼的一個例子Java
- 從位元組碼視角看java字串的拼接Java字串