• javap使用


    javap使用


    一、javap

    javap是JDK自带的反汇编器,可以查看java编译器生成的字节码。

    二、语法

    javap [ 命令选项 ] [class]
    

    三、命令项

    -help  --help  -?        输出此用法消息
    -version                 版本信息
    -v  -verbose             输出附加信息
    -l                       输出行号和本地变量表
    -public                  仅显示公共类和成员
    -protected               显示受保护的/公共类和成员
    -package                 显示程序包/受保护的/公共类
                             和成员 (默认)
    -p  -private             显示所有类和成员
    -c                       对代码进行反汇编
    -s                       输出内部类型签名
    -sysinfo                 显示正在处理的类的
                             系统信息 (路径, 大小, 日期, MD5 散列)
    -constants               显示最终常量
    -classpath <path>        指定查找用户类文件的位置
    -cp <path>               指定查找用户类文件的位置
    -bootclasspath <path>    覆盖引导类文件的位置
    

    四、字节码含义

    1. 栈和局部变量操作

      • 将常量压入栈

          aconst_null         将null对象引用压入栈 
          iconst_m1           将int类型常量-1压入栈 
          iconst_[x]         	将int类型常量x压入栈 
          lconst_[x]          将long类型常量x压入栈 
          fconst_[x]          将float类型常量x压入栈 
          dconst_[x]          将double类型常量0压入栈
          bipush              将8位带符号整数压入栈 
          sipush              将16位带符号整数压入栈 
          ldc                 把常量池中的项压入栈 
          ldc_w               把常量池中的项压入栈(使用宽索引) 
          ldc2_w              把常量池中long类型或者double类型的项压入栈(使用宽索引)
        
      • 从栈中的局部变量中装载值

          iload               从局部变量中装载int类型值
          iload_[x]           从局部变量x中装载int类型值 
          lload               从局部变量中装载long类型值
          lload_[x]           从局部变量x中装载long类型值  
          fload               从局部变量中装载float类型值 
          fload_[x]           从局部变量x中装载float类型值 
          dload               从局部变量中装载double类型值 
          dload_[x]           从局部变量x中装载double类型值
          aload               从局部变量中装载引用类型值(refernce) 
          aload_[x]           从局部变量x中装载引用类型值
        
      • 从数组中装载值

          iaload              从数组中装载int类型值 
          laload              从数组中装载long类型值 
          faload              从数组中装载float类型值 
          daload              从数组中装载double类型值 
          baload              从数组中装载byte类型或boolean类型值 
          caload              从数组中装载char类型值 
          saload              从数组中装载short类型值 
          aaload              从数组中装载引用类型值 
        
      • 将栈中的值存入局部变量

          istore              将int类型值存入局部变量 
          istore_[x]          将int类型值存入局部变量x
          lstore              将long类型值存入局部变量
          lstore_[x]          将long类型值存入局部变量x  
          fstore              将float类型值存入局部变量
          fstore_[x]          将float类型值存入局部变量x  
          dstore              将double类型值存入局部变量 
          dstore_[x]          将double类型值存入局部变量x
          astore              将将引用类型或returnAddress类型值存入局部变量 
          astore_[x]          将将引用类型或returnAddress类型值存入局部变量x 
        
      • 将栈中的值存入数组中

          iastore             将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类型的局部变量上 
        
    2. 逻辑运算

      • 移位操作

          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类型的数值取反
        
    3. 对象和数组

      • 对象操作

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

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

      • 条件分支指令

          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             	从子例程返回 
        
    5. 方法调用与返回

      • 方法调用

          invokcvirtual      	运行时按照对象的类来调用实例方法 
          invokespecial    	根据编译时类型来调用实例方法 
          invokestatic     	调用类(静态)方法 
          invokcinterface   	调用接口方法 
        
      • 方法返回

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

          montiorenter        进入并获取对象监视器 
          monitorexit         释放并退出对象监视器 
        

    五、JVM指令助记符

    1. 变量到操作数栈:iload,iload_<n>,lload,lload_<n>,fload,fload_<n>,dload,dload_<n>,aload,aload_<n>

    2. 操作数栈到变量:istore,istore_<n>,lstore,lstore_<n>,fstore,fstore_<n>,dstore,dstor_<n>,astore,astore_<n>

    3. 常数到操作数栈:bipush,sipush,ldc,ldc_w,ldc2_w,aconst_null,iconst_ml,iconst_<i>,lconst_<l>,fconst_<f>,dconst_<d>

    4. 加:iadd,ladd,fadd,dadd

    5. 减:isub,lsub,fsub,dsub

    6. 乘:imul,lmul,fmul,dmul

    7. 除:idiv,ldiv,fdiv,ddiv

    8. 余数:irem,lrem,frem,drem

    9. 取负:ineg,lneg,fneg,dneg

    10. 移位:ishl,lshr,iushr,lshl,lshr,lushr

    11. 按位或:ior,lor

    12. 按位与:iand,land

    13. 按位异或:ixor,lxor

    14. 类型转换:i2l,i2f,i2d,l2f,l2d,f2d(放宽数值转换) ;i2b,i2c,i2s,l2i,f2i,f2l,d2i,d2l,d2f(缩窄数值转换)

    15. 创建类实便:new

    16. 创建新数组:newarray,anewarray,multianwarray

    17. 访问类的域和类实例域:getfield,putfield,getstatic,putstatic

    18. 把数据装载到操作数栈:baload,caload,saload,iaload,laload,faload,daload,aaload

    19. 从操作数栈存存储到数组:bastore,castore,sastore,iastore,lastore,fastore,dastore,aastore

    20. 获取数组长度:arraylength

    21. 检相类实例或数组属性:instanceof,checkcast

    22. 操作数栈管理:pop,pop2,dup,dup2,dup_xl,dup2_xl,dup_x2,dup2_x2,swap

    23. 有条件转移: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

    24. 复合条件转移:tableswitch,lookupswitch

    25. 无条件转移:goto,goto_w,jsr,jsr_w,ret

    26. 调度对象的实便方法:invokevirtual

    27. 调用由接口实现的方法:invokeinterface

    28. 调用需要特殊处理的实例方法:invokespecial

    29. 调用命名类中的静态方法:invokestatic

    30. 方法返回:ireturn,lreturn,freturn,dreturn,areturn,return

    31. 异常:athrow

    32. finally关键字的实现使用:jsr,jsr_w,ret

    六、jvm内存模型

  • 相关阅读:
    tr的最后一个td
    Jquery的parent方法,这里只讲parent方法
    js判断字符串包含字符串的方法 | 标签包含文本
    js中substring和substr的用法
    一个由印度人编写的VC串口类
    VS2010编译Qt5.4.0静态库
    QT5.4关联VS2010,配置VAssistX关联Qt类
    iOS 关于tableView中有多个textField,输入框被遮住的解决方法
    iOS 之URL schemes
    iOS 之改变状态栏颜色
  • 原文地址:https://www.cnblogs.com/wscy/p/9194157.html
Copyright © 2020-2023  润新知