java 虚拟机字节码指令表

字节码助记符指令含义
0x00nop什么都不做。
0x01aconst_null将 null 推送至栈顶。
0x02iconst_m1将 int 型-1 推送至栈顶。
0x03iconst_0将 int 型 0 推送至栈顶。
0x04iconst_1将 int 型 1 推送至栈顶。
0x05iconst_2将 int 型 2 推送至栈顶。
0x06iconst_3将 int 型 3 推送至栈顶。
0x07iconst_4将 int 型 4 推送至栈顶。
0x08iconst_5将 int 型 5 推送至栈顶。
0x09lconst_0将 long 型 0 推送至栈顶。
0x0alconst_1将 long 型 1 推送至栈顶。
0x0bfconst_0将 float 型 0 推送至栈顶。
0x0cfconst_1将 float 型 1 推送至栈顶。
0x0dfconst_2将 float 型 2 推送至栈顶。
0x0edconst_0将 double 型 0 推送至栈顶。
0x0fdconst_1将 double 型 1 推送至栈顶。
0x10bipush将单字节的常量值(-128~127) 推送至栈顶。
0x11sipush将一个短整型常量值(-32768~32767) 推送至栈顶。
0x12ldc将 int, float 或 String 型常量值从常量池中推送至栈顶。
0x13ldc_w将 int, float 或 String 型常量值从常量池中推送至栈顶(宽索引)。
0x14ldc2_w将 long 或 double 型常量值从常量池中推送至栈顶(宽索引)。
0x15iload将指定的 int 型局部变量推送至栈顶。
0x16lload将指定的 long 型局部变量推送至栈顶。
0x17fload将指定的 float 型局部变量推送至栈顶。
0x18dload将指定的 double 型局部变量推送至栈顶。
0x19aload将指定的引用类型局部变量推送至栈顶。
0x1aiload_0将第一个 int 型局部变量推送至栈顶。
0x1biload_1将第二个 int 型局部变量推送至栈顶。
0x1ciload_2将第三个 int 型局部变量推送至栈顶。
0x1diload_3将第四个 int 型局部变量推送至栈顶。
0x1elload_0将第一个 long 型局部变量推送至栈顶。
0x1flload_1将第二个 long 型局部变量推送至栈顶。
0x20lload_2将第三个 long 型局部变量推送至栈顶。
0x21lload_3将第四个 long 型局部变量推送至栈顶。
0x22fload_0将第一个 float 型局部变量推送至栈顶。
0x23fload_1将第二个 float 型局部变量推送至栈顶。
0x24fload_2将第三个 float 型局部变量推送至栈顶
0x25fload_3将第四个 float 型局部变量推送至栈顶。
0x26dload_0将第一个 double 型局部变量推送至栈顶。
0x27dload_1将第二个 double 型局部变量推送至栈顶。
0x28dload_2将第三个 double 型局部变量推送至栈顶。
0x29dload_3将第四个 double 型局部变量推送至栈顶。
0x2aaload_0将第一个引用类型局部变量推送至栈顶。
0x2baload_1将第二个引用类型局部变量推送至栈顶。
0x2caload_2将第三个引用类型局部变量推送至栈顶。
0x2daload_3将第四个引用类型局部变量推送至栈顶。
0x2eiaload将 int 型数组指定索引的值推送至栈顶。
0x2flaload将 long 型数组指定索引的值推送至栈顶。
0x30faload将 float 型数组指定索引的值推送至栈顶。
0x31daload将 double 型数组指定索引的值推送至栈顶。
0x32aaload将引用型数组指定索引的值推送至栈顶。
0x33baload将 boolean 或 byte 型数组指定索引的值推送至栈顶。
0x34caload将 char 型数组指定索引的值推送至栈顶。
0x35saload将 short 型数组指定索引的值推送至栈顶。
0x36istore将栈顶 int 型数值存入指定局部变量。
0x37lstore将栈顶 long 型数值存入指定局部变量。
0x38fstore将栈顶 float 型数值存入指定局部变量。
0x39dstore将栈顶 double 型数值存入指定局部变量。
0x3aastore将栈顶引用型数值存入指定局部变量。
0x3bistore_0将栈顶 int 型数值存入第一个局部变量。
0x3cistore_1将栈顶 int 型数值存入第二个局部变量。
0x3distore_2将栈顶 int 型数值存入第三个局部变量。
0x3eistore_3将栈顶 int 型数值存入第四个局部变量。
0x3flstore_0将栈顶 long 型数值存入第一个局部变量。
0x40lstore_1将栈顶 long 型数值存入第二个局部变量。
0x41lstore_2将栈顶 long 型数值存入第三个局部变量。
0x42lstore_3将栈顶 long 型数值存入第四个局部变量。
0x43fstore_0将栈顶 float 型数值存入第一个局部变量。
0x44fstore_1将栈顶 float 型数值存入第二个局部变量。
0x45fstore_2将栈顶 float 型数值存入第三个局部变量。
0x46fstore_3将栈顶 float 型数值存入第四个局部变量。
0x47dstore_0将栈顶 double 型数值存入第一个局部变量。
0x48dstore_1将栈顶 double 型数值存入第二个局部变量。
0x49dstore_2将栈顶 double 型数值存入第三个局部变量。
0x4adstore_3将栈顶 double 型数值存入第四个局部变量。
0x4bastore_0将栈顶引用型数值存入第一个局部变量。
0x4castore_1将栈顶引用型数值存入第二个局部变量。
0x4dastore_2将栈顶引用型数值存入第三个局部变量
0x4eastore_3将栈顶引用型数值存入第四个局部变量。
0x4fiastore将栈顶 int 型数值存入指定数组的指定索引位置
0x50lastore将栈顶 long 型数值存入指定数组的指定索引位置。
0x51fastore将栈顶 float 型数值存入指定数组的指定索引位置。
0x52dastore将栈顶 double 型数值存入指定数组的指定索引位置。
0x53aastore将栈顶引用型数值存入指定数组的指定索引位置。
0x54bastore将栈顶 boolean 或 byte 型数值存入指定数组的指定索引位置。
0x55castore将栈顶 char 型数值存入指定数组的指定索引位置
0x56sastore将栈顶 short 型数值存入指定数组的指定索引位置。
0x57pop将栈顶数值弹出(数值不能是 long 或 double 类型的)。
0x58pop2将栈顶的一个(long 或 double 类型的) 或两个数值弹出(其它)。
0x59dup复制栈顶数值并将复制值压入栈顶。
0x5adup_x1复制栈顶数值并将两个复制值压入栈顶。
0x5bdup_x2复制栈顶数值并将三个(或两个)复制值压入栈顶。
0x5cdup2复制栈顶一个(long 或 double 类型的)或两个(其它)数值并将复制值压入栈顶。
0x5ddup2_x1dup_x1 指令的双倍版本。
0x5edup2_x2dup_x2 指令的双倍版本。
0x5fswap将栈最顶端的两个数值互换(数值不能是 long 或 double 类型的)。
0x60iadd将栈顶两 int 型数值相加并将结果压入栈顶。
0x61ladd将栈顶两 long 型数值相加并将结果压入栈顶。
0x62fadd将栈顶两 float 型数值相加并将结果压入栈顶。
0x63dadd将栈顶两 double 型数值相加并将结果压入栈顶。
0x64isub将栈顶两 int 型数值相减并将结果压入栈顶。
0x65lsub将栈顶两 long 型数值相减并将结果压入栈顶。
0x66fsub将栈顶两 float 型数值相减并将结果压入栈顶。
0x67dsub将栈顶两 double 型数值相减并将结果压入栈顶。
0x68imul将栈顶两 int 型数值相乘并将结果压入栈顶。。
0x69lmul将栈顶两 long 型数值相乘并将结果压入栈顶。
0x6afmul将栈顶两 float 型数值相乘并将结果压入栈顶。
0x6bdmul将栈顶两 double 型数值相乘并将结果压入栈顶。
0x6cidiv将栈顶两 int 型数值相除并将结果压入栈顶。
0x6dldiv将栈顶两 long 型数值相除并将结果压入栈顶。
0x6efdiv将栈顶两 float 型数值相除并将结果压入栈顶。
0x6fddiv将栈顶两 double 型数值相除并将结果压入栈顶。
0x70irem将栈顶两 int 型数值作取模运算并将结果压入栈顶。
0x71lrem将栈顶两 long 型数值作取模运算并将结果压入栈顶。
0x72frem将栈顶两 float 型数值作取模运算并将结果压入栈顶。
0x73drem将栈顶两 double 型数值作取模运算并将结果压入栈顶。
0x74ineg将栈顶 int 型数值取负并将结果压入栈顶。
0x75lneg将栈顶 long 型数值取负并将结果压入栈顶。
0x76fneg将栈顶 float 型数值取负并将结果压入栈顶。
0x77dneg将栈顶 double 型数值取负并将结果压入栈顶。
0x78ishl将 int 型数值左移位指定位数并将结果压入栈顶。
0x79lshl将 long 型数值左移位指定位数并将结果压入栈顶。
0x7aishr将 int 型数值右(有符号)移位指定位数并将结果压入栈顶。
0x7blshr将 long 型数值右(有符号)移位指定位数并将结果压入栈顶。
0x7ciushr将 int 型数值右(无符号)移位指定位数并将结果压入栈顶。
0x7dlushr将 long 型数值右(无符号)移位指定位数并将结果压入栈顶。
0x7eiand将栈顶两 int 型数值作“按位与”并将结果压入栈顶。
0x7fland将栈顶两 long 型数值作“按位与”并将结果压入栈顶。
0x80ior将栈顶两 int 型数值作“按位或”并将结果压入栈顶。
0x81lor将栈顶两 long 型数值作“按位或”并将结果压入栈顶。
0x82ixor将栈顶两 int 型数值作“按位异或”并将结果压入栈顶。
0x83lxor将栈顶两 long 型数值作“按位异或”并将结果压入栈顶。
0x84iinc将指定 int 型变量增加指定值。
0x85i2l将栈顶 int 型数值强制转换成 long 型数值并将结果压入栈顶。
0x86i2f将栈顶 int 型数值强制转换成 float 型数值并将结果压入栈顶。
0x87i2d将栈顶 int 型数值强制转换成 double 型数值并将结果压入栈顶。
0x88l2i将栈顶 long 型数值强制转换成 int 型数值并将结果压入栈顶。
0x89l2f将栈顶 long 型数值强制转换成 float 型数值并将结果压入栈顶。
0x8al2d将栈顶 long 型数值强制转换成 double 型数值并将结果压入栈顶。
0x8bf2i将栈顶 float 型数值强制转换成 int 型数值并将结果压入栈顶。
0x8cf2l将栈顶 float 型数值强制转换成 long 型数值并将结果压入栈顶。
0x8df2d将栈顶float型数值强制转换成double型数值并将结果压入栈顶。
0x8ed2i将栈顶 double 型数值强制转换成 int 型数值并将结果压入栈顶。
0x8fd2l将栈顶 double 型数值强制转换成 long 型数值并将结果压入栈顶。
0x90d2f将栈顶double型数值强制转换成float型数值并将结果压入栈顶。
0x91i2b将栈顶 int 型数值强制转换成 byte 型数值并将结果压入栈顶。
0x92i2c将栈顶 int 型数值强制转换成 char 型数值并将结果压入栈顶。
0x93i2s将栈顶 int 型数值强制转换成 short 型数值并将结果压入栈顶。
0x94lcmp比较栈顶两 long 型数值大小,并将结果(1, 0, -1)压入栈顶。
0x95fcmpl比较栈顶两 float 型数值大小,并将结果(1, 0, -1)压入栈顶;当其中一个数值为“NaN” 时,将-1 压入栈顶。
0x96fcmpg比较栈顶两 float 型数值大小,并将结果(1, 0, -1)压入栈顶;当其中一个数值为“NaN” 时,将 1 压入栈顶。
0x97dcmpl比较栈顶两 double 型数值大小,并将结果(1, 0, -1)压入栈顶;当其中一个数值为“NaN” 时,将-1 压入栈顶。
0x98dcmpg比较栈顶两 double 型数值大小,并将结果(1, 0, -1)压入栈顶;当其中一个数值为“NaN” 时,将 1 压入栈顶。
0x99ifeq当栈顶 int 型数值等于 0 时跳转。
0x9aifne当栈顶 int 型数值不等于 0 时跳转。
0x9biflt当栈顶 int 型数值小于 0 时跳转。
0x9cifge当栈顶 int 型数值大于等于 0 时跳转。
0x9difgt当栈顶 int 型数值大于 0 时跳转。
0x9eifle当栈顶 int 型数值小于等于 0 时跳转。
0x9fif_icmpeq比较栈顶两 int 型数值大小,当结果等于 0 时跳转。
0xa0if_icmpne比较栈顶两 int 型数值大小,当结果不等于 0 时跳转。
0xa1if_icmplt比较栈顶两 int 型数值大小,当结果小于 0 时跳转。
0xa2if_icmpge比较栈顶两 int 型数值大小,当结果大于等于 0 时跳转。
0xa3if_icmpgt比较栈顶两 int 型数值大小,当结果大于 0 时跳转
0xa4if_icmple比较栈顶两 int 型数值大小,当结果小于等于 0 时跳转。
0xa5if_acmpeq比较栈顶两引用型数值,当结果相等时跳转。
0xa6if_acmpne比较栈顶两引用型数值,当结果不相等时跳转。
0xa7goto无条件跳转。
0xa8jsr跳转至指定 16 位 offset 位置,并将 jsr 下一条指令地址压入栈顶。
0xa9ret返回至局部变量指定的 index 的指令位置(一般与 jsr, jsr_w联合使用)。
0xaatableswitch用于 switch 条件跳转, case 值连续(可变长度指令)。
0xablookupswitch用于 switch 条件跳转, case 值不连续(可变长度指令)。
0xacireturn从当前方法返回 int。
0xadlreturn从当前方法返回 long。
0xaefreturn从当前方法返回 float。
0xafdreturn从当前方法返回 double。
0xb0areturn从当前方法返回对象引用。
0xb1return从当前方法返回 void。
0xb2getstatic获取指定类的静态域,并将其值压入栈顶。
0xb3putstatic为指定的类的静态域赋值。
0xb4getfield获取指定类的实例域,并将其值压入栈顶。
0xb5putfield为指定的类的实例域赋值。
0xb6invokevirtual调用实例方法。
0xb7invokespecial调用超类构造方法,实例初始化方法,私有方法。
0xb8invokestatic调用静态方法。
0xb9“invokeinterface”调用接口方法。
0xbainvokedynamic调用动态链接方法①。
0xbbnew创建一个对象,并将其引用值压入栈顶。
0xbcnewarray创建一个指定原始类型(如 int、 float、 char??)的数组,并将其引用值压入栈顶。
0xbdanewarray创建一个引用型(如类,接口, 数组)的数组,并将其引用值压入栈顶。
0xbearraylength获得数组的长度值并压入栈顶。
0xbfathrow将栈顶的异常抛出。
0xc0checkcast检验类型转换,检验未通过将抛出 ClassCastException。
0xc1instanceof检验对象是否是指定的类的实例,如果是将 1 压入栈顶,否则将0 压入栈顶。
0xc2monitorenter获得对象的 monitor,用于同步方法或同步块。
0xc3monitorexit释放对象的 monitor,用于同步方法或同步块。
0xc4wide扩展访问局部变量表的索引宽度。
0xc5multianewarray创建指定类型和指定维度的多维数组(执行该指令时,操作栈中必须包含各维度的长度值),并将其引用值压入栈顶。
0xc6ifnull为 null 时跳转。
0xc7ifnonnull不为 null 时跳转。
0xc8goto_w无条件跳转(宽索引)。
0xc9jsr_w跳转至指定 32 位地址偏移量位置,并将 jsr_w 下一条指令地址压入栈顶。
保留指令
0xcabreakpoint调试时的断点标志。
0xfeimpdep1用于在特定硬件中使用的语言后门。
0xffimpdep1用于在特定硬件中使用的语言后门。
  • 2
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值