java汇编指令含义

java汇编指令含义

Posted by AnAn on January 4, 2021

命令:javap -c xxx.class

  • 如果提示:“错误: 找不到类: xxx.class”
  • 首先得把java文件编译成class文件

    常量压入栈操作- iconst_1 将int类型常量 1压入栈

  • iconst_m1 将int类型常量-1压入栈
  • lconst_1 将long类型常量1压入栈
  • fconst_1 将float类型常量1压入栈
  • dconst_1 将double类型常量压入栈
  • bipush 将一个8位带符号整数压入栈中
  • sipush 将一个16位带符号整数压入栈中
  • idc 把常量池中的项压入栈
  • idc_w 把常量池中的项压入栈(使用宽索引)
  • idc2_w 把常量池中long类型或者double类型的项压入栈(使用款索引)

    从栈中局部变量中装载值的命令- iload 从局部变量中装载int类型值

  • lload 从局部变量中装载long类型值
  • fload 从局部变量中装载float类型值
  • dload 从局部变量中装载double类型值
  • aload 从局部变量中装载引用类型的值(refernce)
  • iload_0 从局部变量0中装载int类型值
  • lload_0 从局部变量0中装载long类型值
  • fload_0 从局部变量0中装载float类型值
  • dload_0 从局部变量0中装载double类型值
  • aload_0 从局部变量0中装载引用类型值
  • iaload 从数组中装载int类型值
  • laload 从数组中装载long类型值
  • faload 从数组中装载float类型值
  • daload 从数组中装载double类型值
  • aaload 从数组中装载引用类型值
  • baload 从数组中装载byte类型或boolean类型值
  • caload 从数组中装载char类型值
  • saload 从数组中装载short类型值

    将栈中的值存入局部变量的指令

  • istore 将int类型值存入局部变量
  • lstore 将long类型值存入局部变量
  • fstore 将float类型值存入局部变量
  • dstore 将double类型值存入局部变量
  • astore 将将引用类型或returnAddress类型值存入局部变量
  • istore_0 将int类型值存入局部变量0
  • lstore_1 将long类型值存入局部变量1
  • fstore_0 将float类型值存入局部变量0
  • dstore_0 将double类型值存入局部变量0
  • astore_3 将引用类型或returnAddress类型值存入局部变量3
  • astore 将int类型值存入数组中
  • lastore 将long类型值存入数组中
  • fastore 将float类型值存入数组中
  • dastore 将double类型值存入数组中
  • aastore 将引用类型值存入数组中
  • bastore 将byte类型或者boolean类型值存入数组中
  • castore 将char类型值存入数组中
  • sastore 将short类型值存入数组中
  • wide指令
  • wide 使用附加字节扩展局部变量索引

    通用(无类型)栈操作- nop 不做任何操作

  • pop 弹出栈顶端一个字长的内容
  • pop2 弹出栈顶端两个字长的内容
  • dup 复制栈顶部一个字长内容
  • dup_x1 复制栈顶部一个字长的内容,然后将复制内容及原来弹出的两个字长的内容压入栈
  • dup_x2 复制栈顶部一个字长的内容,然后将复制内容及原来弹出的三个字长的内容压入栈
  • dup2 复制栈顶部两个字长内容
  • dup2_x1 复制栈顶部两个字长的内容,然后将复制内容及原来弹出的三个字长的内容压入栈
  • dup2_x2 复制栈顶部两个字长的内容,然后将复制内容及原来弹出的四个字长的内容压入栈
  • swap 交换栈顶部两个字长内容类型转换
  • i2l 把int类型的数据转化为long类型
  • i2f 把int类型的数据转化为float类型
  • i2d 把int类型的数据转化为double类型
  • l2i 把long类型的数据转化为int类型
  • l2f 把long类型的数据转化为float类型
  • l2d 把long类型的数据转化为double类型
  • f2i 把float类型的数据转化为int类型
  • f2l 把float类型的数据转化为long类型
  • f2d 把float类型的数据转化为double类型
  • d2i 把double类型的数据转化为int类型
  • d2l 把double类型的数据转化为long类型
  • d2f 把double类型的数据转化为float类型
  • i2b 把int类型的数据转化为byte类型
  • i2c 把int类型的数据转化为char类型
  • i2s 把int类型的数据转化为short类型

    整数运算

  • iadd 执行int类型的加法
  • ladd 执行long类型的加法
  • isub 执行int类型的减法
  • lsub 执行long类型的减法
  • imul 执行int类型的乘法
  • lmul 执行long类型的乘法
  • idiv 执行int类型的除法
  • ldiv 执行long类型的除法
  • irem 计算int类型除法的余数
  • lrem 计算long类型除法的余数
  • ineg 对一个int类型值进行取反操作
  • lneg 对一个long类型值进行取反操作
  • iinc 把一个常量值加到一个int类型的局部变量上

    位移操作

  • ishl 执行int类型的向左移位操作
  • lshl 执行long类型的向左移位操作
  • ishr 执行int类型的向右移位操作
  • lshr 执行long类型的向右移位操作
  • iushr 执行int类型的向右逻辑移位操作
  • lushr 执行long类型的向右逻辑移位操作

    按位布尔运算

  • iand 对int类型值进行“逻辑与”操作
  • land 对long类型值进行“逻辑与”操作
  • ior 对int类型值进行“逻辑或”操作
  • lor 对long类型值进行“逻辑或”操作
  • ixor 对int类型值进行“逻辑异或”操作
  • lxor 对long类型值进行“逻辑异或”操作

    浮点运算

  • fadd 执行float类型的加法
  • dadd 执行double类型的加法
  • fsub 执行float类型的减法
  • dsub 执行double类型的减法
  • fmul 执行float类型的乘法
  • dmul 执行double类型的乘法
  • fdiv 执行float类型的除法
  • ddiv 执行double类型的除法
  • frem 计算float类型除法的余数
  • drem 计算double类型除法的余数
  • fneg 将一个float类型的数值取反
  • dneg 将一个double类型的数值取反

    对象操作指令

  • new 创建一个新对象
  • checkcast 确定对象为所给定的类型
  • getfield 从对象中获取字段
  • putfield 设置对象中字段的值
  • getstatic 从类中获取静态字段
  • putstatic 设置类中静态字段的值
  • instanceof 判断对象是否为给定的类型

    数组操作指令

  • newarray 分配数据成员类型为基本上数据类型的新数组
  • anewarray 分配数据成员类型为引用类型的新数组
  • arraylength 获取数组长度
  • multianewarray 分配新的多维数组

    条件分支指令

  • ifeq 如果等于0,则跳转
  • ifne 如果不等于0,则跳转
  • iflt 如果小于0,则跳转
  • ifge 如果大于等于0,则跳转
  • ifgt 如果大于0,则跳转
  • ifle 如果小于等于0,则跳转
  • if_icmpcq 如果两个int值相等,则跳转
  • if_icmpne 如果两个int类型值不相等,则跳转
  • if_icmplt 如果一个int类型值小于另外一个int类型值,则跳转
  • if_icmpge 如果一个int类型值大于或者等于另外一个int类型值,则跳转
  • if_icmpgt 如果一个int类型值大于另外一个int类型值,则跳转
  • if_icmple 如果一个int类型值小于或者等于另外一个int类型值,则跳转
  • ifnull 如果等于null,则跳转
  • ifnonnull 如果不等于null,则跳转
  • if_acmpeq 如果两个对象引用相等,则跳转
  • if_acmpnc 如果两个对象引用不相等,则跳转

    比较指令

  • lcmp 比较long类型值
  • fcmpl 比较float类型值(当遇到NaN时,返回-1)
  • fcmpg 比较float类型值(当遇到NaN时,返回1)
  • dcmpl 比较double类型值(当遇到NaN时,返回-1)
  • dcmpg 比较double类型值(当遇到NaN时,返回1)

    无条件转移指令

  • goto 无条件跳转
  • goto_w 无条件跳转(宽索引)
  • –表跳转指令
  • tableswitch 通过索引访问跳转表,并跳转
  • lookupswitch 通过键值匹配访问跳转表,并执行跳转操作
  • –异常
  • athrow 抛出异常或错误
  • –finally子句
  • jsr 跳转到子例程
  • jsr_w 跳转到子例程(宽索引)
  • rct 从子例程返回

    方法调用指令

  • invokcvirtual 运行时按照对象的类来调用实例方法
  • invokespecial 根据编译时类型来调用实例方法 ==>调用超类构造方法、实例初始化方法、私有方法
  • invokestatic 调用类(静态)方法
  • invokcinterface 调用接口方法

    方法返回指令

  • ireturn 从方法中返回int类型的数据
  • lreturn 从方法中返回long类型的数据
  • freturn 从方法中返回float类型的数据
  • dreturn 从方法中返回double类型的数据
  • areturn 从方法中返回引用类型的数据
  • return 从方法中返回,返回值为void

    线程同步

  • monitorenter 进入并获取对象监视器 (获取对象锁)
  • monitorexit 释放并退出对象监视器 (释放对象锁)
  • 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,ldc2w,aconst_null,iconst_ml,iconst,lconst_,fconst_,dconst_
  • 加: iadd,ladd,fadd,dadd
  • 减: isub,lsub,fsub,dsub
  • 乘: 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
  • 调度对象的实便方法: invokevirtual
  • 调用由接口实现的方法: invokeinterface
  • 调用需要特殊处理的实例方法:invokespecial
  • 调用命名类中的静态方法: invokestatic
  • 方法返回: ireturn,lreturn,freturn,dreturn,areturn,return
  • 异常: athrow
  • finally关键字的实现使用: jsr,jsr_w,ret