前言

本文整理了 Java 虚拟机指令操作码和助记符之间的映射关系,可以用于日常学习 Java 字节码时快速查阅。需要注意的是,操作码 186 对应的 invokedynamic 指令是 JDK 7 版本新增的指令,在 JDK 7 之前的版本没有该指令。

常量 Constants

字节码(十进制)字节码(十六进制)助记符指令含义
000x00nop无操作
010x01aconst_null将 null 推至栈顶
020x02iconst_m1将 int 型 -1 推至栈顶
030x03iconst_0将 int 型 0 推至栈顶
040x04iconst_1将 int 型 1 推至栈顶
050x05iconst_2将 int 型 2 推至栈顶
060x06iconst_3将 int 型 3 推至栈顶
070x07iconst_4将 int 型 4 推至栈顶
080x08iconst_5将 int 型 5 推至栈顶
090x09lconst_0将 long 型 0 推至栈顶
100x0alconst_1将 long 型 1 推至栈顶
110x0bfconst_0将 float 型 0 推至栈顶
120x0cfconst_1将 float 型 1 推至栈顶
130x0dfconst_2将 float 型 2 推至栈顶
140x0edconst_0将 double 型 0 推至栈顶
150x0fdconst_1将 double 型 1 推至栈顶
160x10bipush将单字节的常量值(-128 ~ 127)推至栈顶
170x11sipush将一个短整型常量(-32768 ~ 32767)推至栈顶
180x12ldc将 int,float 或 String 型常量值从常量池中推至栈顶
190x13ldc_w将 int,float 或 String 型常量值从常量池中推至栈顶(宽索引)
200x14ldc2_w将 long 或 double 型常量值从常量池中推至栈顶(宽索引)

加载 Loads

字节码(十进制)字节码(十六进制)助记符指令含义
210x15iload将指定的 int 型本地变量推至栈顶
220x16lload将指定的 long 型本地变量推至栈顶
230x17fload将指定的 float 型本地变量推至栈顶
240x18dload将指定的 double 型本地变量推至栈顶
250x19aload将指定的引用类型本地变量推至栈顶
260x1aiload_0将第一个 int 型本地变量推至栈顶
270x1biload_1将第二个 int 型本地变量推至栈顶
280x1ciload_2将第三个 int 型本地变量推至栈顶
290x1diload_3将第四个 int 型本地变量推至栈顶
300x1elload_0将第一个 long 型本地变量推至栈顶
310x1flload_1将第二个 long 型本地变量推至栈顶
320x20lload_2将第三个 long 型本地变量推至栈顶
330x21lload_3将第四个 long 型本地变量推至栈顶
340x22fload_0将第一个 float 型本地变量推至栈顶
350x23fload_1将第二个 float 型本地变量推至栈顶
360x24fload_2将第三个 float 型本地变量推至栈顶
370x25fload_3将第四个 float 型本地变量推至栈顶
380x26dload_0将第一个 double 型本地变量推至栈顶
390x27dload_1将第二个 double 型本地变量推至栈顶
400x28dload_2将第三个 double 型本地变量推至栈顶
410x29dload_3将第四个 double 型本地变量推至栈顶
420x2aaload_0将第一个引用类型本地变量推至栈顶
430x2baload_1将第二个引用类型本地变量推至栈顶
440x2caload_2将第三个引用类型本地变量推至栈顶
450x2daload_3将第四个引用类型本地变量推至栈顶
460x2eiaload将 int 型数组指定索引的值推至栈顶
470x2flaload将 long 型数组指定索引的值推至栈顶
480x30faload将 float 型数组指定索引的值推至栈顶
490x31daload将 double 型数组指定索引的值推至栈顶
500x32aaload将引用类型数组指定索引的值推至栈顶
510x33baload将 boolean 或 byte 型数组指定索引的值推至栈顶
520x34caload将 char 型数组指定索引的值推至栈顶
530x35saload将 short 型数组指定索引的值推至栈顶

存储 Stores

字节码(十进制)字节码(十六进制)助记符指令含义
540x36istore将栈顶 int 型数值存入指定本地变量
550x37lstore将栈顶 long 型数值存入指定本地变量
560x38fstore将栈顶 float 型数值存入指定本地变量
570x39dstore将栈顶 double 型数值存入指定本地变量
580x3aastore将栈顶引用类型数值存入指定本地变量
590x3bistore_0将栈顶 int 型数值存入第一个本地变量
600x3cistore_1将栈顶 int 型数值存入第二个本地变量
610x3distore_2将栈顶 int 型数值存入第三个本地变量
620x3eistore_3将栈顶 int 型数值存入第四个本地变量
630x3flstore_0将栈顶 long 型数值存入第一个本地变量
640x40lstore_1将栈顶 long 型数值存入第二个本地变量
650x41lstore_2将栈顶 long 型数值存入第三个本地变量
660x42lstore_3将栈顶 long 型数值存入第四个本地变量
670x43fstore_0将栈顶 float 型数值存入第一个本地变量
680x44fstore_1将栈顶 float 型数值存入第二个本地变量
690x45fstore_2将栈顶 float 型数值存入第三个本地变量
700x46fstore_3将栈顶 float 型数值存入第四个本地变量
710x47dstore_0将栈顶 double 型数值存入第一个本地变量
720x48dstore_1将栈顶 double 型数值存入第二个本地变量
730x49dstore_2将栈顶 double 型数值存入第三个本地变量
740x4adstore_3将栈顶 double 型数值存入第四个本地变量
750x4bastore_0将栈顶引用型数值存入第一个本地变量
760x4castore_1将栈顶引用型数值存入第二个本地变量
770x4dastore_2将栈顶引用型数值存入第三个本地变量
780x4eastore_3将栈顶引用型数值存入第四个本地变量
790x4fiastore将栈顶 int 型数值存入指定数组的指定索引位置
800x50lastore将栈顶 long 型数值存入指定数组的指定索引位置
810x51fastore将栈顶 float 型数值存入指定数组的指定索引位置
820x52dastore将栈顶 double 型数值存入指定数组的指定索引位置
830x53aastore将栈顶引用型数值存入指定数组的指定索引位置
840x54bastore将栈顶 boolean 或 byte 型数值存入指定数组的指定索引位置
850x55castore将栈顶 char 型数值存入指定数组的指定索引位置
860x56sastore将栈顶 short 型数值存入指定数组的指定索引位置

栈操作 Stack

字节码(十进制)字节码(十六进制)助记符指令含义
870x57pop将栈顶数值弹出(数值不能是 long 或 double 类型的)
880x58pop2将栈顶的一个(对于 long 或 double 类型)或两个数值(对于非 long 或 double 的其他类型)弹出
890x59dup复制栈顶数值并将复制值压入栈顶
900x5adup_x1复制栈顶数值并将两个复制值压入栈顶
910x5bdup_x2复制栈顶数值并将三个(或两个)复制值压入栈顶
920x5cdup2复制栈顶一个(对于 long 或 double 类型)或两个(对于非 long 或 double 的其他类型)数值并将复制值压入栈顶
930x5ddup2_x1dup_x1 指令的双倍版本
940x5edup2_x2dup_x2 指令的双倍版本
950x5fswap将栈顶最顶端的两个数值互换(数值不能是 long 或 double 类型)

数学运算 Math

字节码(十进制)字节码(十六进制)助记符指令含义
960x60iadd将栈顶两 int 型数值相加并将结果压入栈顶
970x61ladd将栈顶两 long 型数值相加并将结果压入栈顶
980x62fadd将栈顶两 float 型数值相加并将结果压入栈顶
990x63dadd将栈顶两 double 型数值相加并将结果压入栈顶
1000x64isub将栈顶两 int 型数值相减并将结果压入栈顶
1010x65lsub将栈顶两 long 型数值相减并将结果压入栈顶
1020x66fsub将栈顶两 float 型数值相减并将结果压入栈顶
1030x67dsub将栈顶两 double 型数值相减并将结果压入栈顶
1040x68imul将栈顶两 int 型数值相乘并将结果压入栈顶
1050x69lmul将栈顶两 long 型数值相乘并将结果压入栈顶
1060x6afmul将栈顶两 float 型数值相乘并将结果压入栈顶
1070x6bdmul将栈顶两 double 型数值相乘并将结果压入栈顶
1080x6cidiv将栈顶两 int 型数值相除并将结果压入栈顶
1090x6dldiv将栈顶两 long 型数值相除并将结果压入栈顶
1100x6efdiv将栈顶两 float 型数值相除并将结果压入栈顶
1110x6fddiv将栈顶两 double 型数值相除并将结果压入栈顶
1120x70irem将栈顶两 int 型数值作取模运算并将结果压入栈顶
1130x71lrem将栈顶两 long 型数值作取模运算并将结果压入栈顶
1140x72frem将栈顶两 float 型数值作取模运算并将结果压入栈顶
1150x73drem将栈顶两 double 型数值作取模运算并将结果压入栈顶
1160x74ineg将栈顶 int 型数值取负并将结果压入栈顶
1170x75lneg将栈顶 long 型数值取负并将结果压入栈顶
1180x76fneg将栈顶 float 型数值取负并将结果压入栈顶
1190x77dneg将栈顶 double 型数值取负并将结果压入栈顶
1200x78ishl将 int 型数值左移指定位数并将结果压入栈顶
1210x79lshl将 long 型数值左移指定位数并将结果压入栈顶
1220x7aishr将 int 型数值右(带符号)移指定位数并将结果压入栈顶
1230x7blshr将 long 型数值右(带符号)移指定位数并将结果压入栈顶
1240x7ciushr将 int 型数值右(无符号)移指定位数并将结果压入栈顶
1250x7dlushr将 long 型数值右(无符号)移指定位数并将结果压入栈顶
1260x7eiand将栈顶两 int 型数值按位与并将结果压入栈顶
1270x7fland将栈顶两 long 型数值按位与并将结果压入栈顶
1280x80ior将栈顶两 int 型数值按位或并将结果压入栈顶
1290x81lor将栈顶两 long 型数值按位或并将结果压入栈顶
1300x82ixor将栈顶两 int 型数值按位异或并将结果压入栈顶
1310x83lxor将栈顶两 long 型数值按位异或并将结果压入栈顶
1320x84iinc将指定 int 型变量增加指定值(如 i++,i–,i+=2 等)

转换 Conversions

字节码(十进制)字节码(十六进制)助记符指令含义
1330x85i2l将栈顶 int 型数值强制转换为 long 型数值并将结果压入栈顶
1340x86i2f将栈顶 int 型数值强制转换为 float 型数值并将结果压入栈顶
1350x87i2d将栈顶 int 型数值强制转换为 double 型数值并将结果压入栈顶
1360x88l2i将栈顶 long 型数值强制转换为 int 型数值并将结果压入栈顶
1370x89l2f将栈顶 long 型数值强制转换为 float 型数值并将结果压入栈顶
1380x8al2d将栈顶 long 型数值强制转换为 double 型数值并将结果压入栈顶
1390x8bf2i将栈顶 float 型数值强制转换为 int 型数值并将结果压入栈顶
1400x8cf2l将栈顶 float 型数值强制转换为 long 型数值并将结果压入栈顶
1410x8df2d将栈顶 float 型数值强制转换为 double 型数值并将结果压入栈顶
1420x8ed2i将栈顶 double 型数值强制转换为 int 型数值并将结果压入栈顶
1430x8fd2l将栈顶 double 型数值强制转换为 long 型数值并将结果压入栈顶
1440x90d2f将栈顶 double 型数值强制转换为 float 型数值并将结果压入栈顶
1450x91i2b将栈顶 int 型数值强制转换为 byte 型数值并将结果压入栈顶
1460x92i2c将栈顶 int 型数值强制转换为 char 型数值并将结果压入栈顶
1470x93i2s将栈顶 int 型数值强制转换为 short 型数值并将结果压入栈顶

比较 Comparisons

字节码(十进制)字节码(十六进制)助记符指令含义
1480x94lcmp比较栈顶两 long 型数值大小,并将结果(1,0 或 -1)压入栈顶
1490x95fcmpl比较栈顶两 float 型数值大小,并将结果(1,0 或 -1)压入栈顶; 当其中一个数值为 NaN 时,将 -1 压入栈顶
1500x96fcmpg比较栈顶两 float 型数值大小,并将结果(1,0 或 -1)压入栈顶; 当其中一个数值为 NaN 时,将 1 压入栈顶
1510x97dcmpl比较栈顶两 double 型数值大小,并将结果(1,0 或 -1)压入栈顶; 当其中一个数值为 NaN 时,将 -1 压入栈顶
1520x98dcmpg比较栈顶两 double 型数值大小,并将结果(1,0 或 -1)压入栈顶; 当其中一个数值为 NaN 时,将 1 压入栈顶
1530x99ifeq当栈顶 int 型数值等于 0 时跳转
1540x9aifne当栈顶 int 型数值不等于 0 时跳转
1550x9biflt当栈顶 int 型数值小于 0 时跳转
1560x9cifge当栈顶 int 型数值大于等于 0 时跳转
1570x9difgt当栈顶 int 型数值大于 0 时跳转
1580x9eifle当栈顶 int 型数值小于等于 0 时跳转
1590x9fif_icmpeq比较栈顶两 int 型数值大小,当结果等于 0 时跳转
1600xa0if_icmpne比较栈顶两 int 型数值大小,当结果不等于 0 时跳转
1610xa1if_icmplt比较栈顶两 int 型数值大小,当结果小于 0 时跳转
1620xa2if_icmpge比较栈顶两 int 型数值大小,当结果大于等于 0 时跳转
1630xa3if_icmpgt比较栈顶两 int 型数值大小,当结果大于 0 时跳转
1640xa4if_icmple比较栈顶两 int 型数值大小,当结果小于等于 0 时跳转
1650xa5if_acmpeq比较栈顶两引用型数值,当结果相等时跳转
1660xa6if_acmpne比较栈顶两引用型数值,当结果不相等时跳转

控制 Control

字节码(十进制)字节码(十六进制)助记符指令含义
1670xa7goto无条件跳转
1680xa8jsr跳转至指定的 16 位 offset 位置,并将 jsr 的下一条指令地址压入栈顶
1690xa9ret返回至本地变量指定的 index 的指令位置(一般与 jsr 或 jsr_w 联合使用)
1700xaatableswitch用于 switch 条件跳转,case 值连续(可变长度指令)
1710xablookupswitch用于 switch 条件跳转,case 值不连续(可变长度指令)
1720xacireturn从当前方法返回 int
1730xadlreturn从当前方法返回 long
1740xaefreturn从当前方法返回 float
1750xafdreturn从当前方法返回 double
1760xb0areturn从当前方法返回对象引用
1770xb1return从当前方法返回 void

引用 References

字节码(十进制)字节码(十六进制)助记符指令含义
1780xb2getstatic获取指定类的静态域,并将其压入栈顶
1790xb3putstatic为指定类的静态域赋值
1800xb4getfield获取指定类的实例域,并将其压入栈顶
1810xb5putfield为指定类的实例域赋值
1820xb6invokevirtual调用实例方法
1830xb7invokespecial调用超类构造方法,实例初始化方法,私有方法
1840xb8invokestatic调用静态方法
1850xb9invokeinterface调用接口方法
1860xbainvokedynamic调用动态方法
1870xbbnew创建一个对象,并将其引用值压入栈顶
1880xbcnewarray创建一个指定的原始类型(如 int,float,char 等)的数组,并将其引用值压入栈顶
1890xbdanewarray创建一个引用型(如类,接口,数组)的数组,并将其引用值压入栈顶
1900xbearraylength获取数组的长度值并压入栈顶
1910xbfathrow将栈顶的异常抛出
1920xc0checkcast检验类型转换,检验未通过将抛出 ClassCastException
1930xc1instanceof检验对象是否是指定类的实际,如果是将 1 压入栈顶,否则将 0 压入栈顶
1940xc2monitorenter获得对象的锁,用于同步方法或同步块
1950xc3monitorexit释放对象的锁,用于同步方法或同步块

扩展 Extended

字节码(十进制)字节码(十六进制)助记符指令含义
1960xc4wide扩展本地变量的宽度
1970xc5multianewarray创建指定类型和指定维度的多维数组(执行该指令时,操作栈中必须包含各维度的长度值),并将其引用压入栈顶
1980xc6ifnull为 null 时跳转
1990xc7ifnonnull不为 null 时跳转
2000xc8goto_w无条件跳转(宽索引)
2010xc9jsr_w跳转至指定的 32 位 offset 位置,并将 jsr_w 的下一条指令地址压入栈顶

保留 Reserved

字节码(十进制)字节码(十六进制)助记符指令含义
2020xcabreakpoint调试断点
2540xfeimpdep1用于在特定硬件中使用的语言后门
2550xffimpdep2用于在特定硬件中使用的语言后门