JVM性能深度调优 之 JVM javap工具

8 篇文章 0 订阅
1 篇文章 0 订阅
本文详细介绍了JVM自带的javap工具,包括其使用方法、作用及JVM指令手册。javap主要用于反汇编字节码文件,通过不同选项可以查看类的详细信息,如行号、本地变量表、代码反汇编等。同时,文章还给出了学习JVM性能调优的相关路线。
摘要由CSDN通过智能技术生成

javap

用法

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

作用

主要用于反汇编字节码文件。

JVM指令手册

栈和局部变量操作  
将常量压入栈的指令  
aconst_null 将null对象引用压入栈  
iconst_m1 将int类型常量-1压入栈  
iconst_0 将int类型常量0压入栈  
iconst_1 将int类型常量1压入栈  
iconst_2 将int类型常量2压入栈  
iconst_3 将int类型常量3压入栈  
iconst_4 将int类型常量4压入栈  
iconst_5 将int类型常量5压入栈  
lconst_0 将long类型常量0压入栈  
lconst_1 将long类型常量1压入栈  
fconst_0 将float类型常量0压入栈  
fconst_1 将float类型常量1压入栈  
dconst_0 将double类型常量0压入栈  
dconst_1 将double类型常量1压入栈  
bipush 将一个8位带符号整数压入栈  
sipush 将16位带符号整数压入栈  
ldc 把常量池中的项压入栈  
ldc_w 把常量池中的项压入栈(使用宽索引)  
ldc2_w 把常量池中long类型或者double类型的项压入栈(使用宽索引)  

从栈中的局部变量中装载值的指令  
iload 从局部变量中装载int类型值  
lload 从局部变量中装载long类型值  
fload 从局部变量中装载float类型值  
dload 从局部变量中装载double类型值  
aload 从局部变量中装载引用类型值(refernce)  
iload_0 从局部变量0中装载int类型值  
iload_1 从局部变量1中装载int类型值  
iload_2 从局部变量2中装载int类型值  
iload_3 从局部变量3中装载int类型值  
lload_0 从局部变量0中装载long类型值  
lload_1 从局部变量1中装载long类型值  
lload_2 从局部变量2中装载long类型值  
lload_3 从局部变量3中装载long类型值  
fload_0 从局部变量0中装载float类型值  
fload_1 从局部变量1中装载float类型值 
fload_2 从局部变量2中装载float类型值  
fload_3 从局部变量3中装载float类型值  
dload_0 从局部变量0中装载double类型值  
dload_1 从局部变量1中装载double类型值  
dload_2 从局部变量2中装载double类型值  
dload_3 从局部变量3中装载double类型值  
aload_0 从局部变量0中装载引用类型值  
aload_1 从局部变量1中装载引用类型值  
aload_2 从局部变量2中装载引用类型值  
aload_3 从局部变量3中装载引用类型值  
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  
istore_1 将int类型值存入局部变量1  
istore_2 将int类型值存入局部变量2  
istore_3 将int类型值存入局部变量3  
lstore_0 将long类型值存入局部变量0  
lstore_1 将long类型值存入局部变量1  
lstore_2 将long类型值存入局部变量2  
lstore_3 将long类型值存入局部变量3  
fstore_0 将float类型值存入局部变量0  
fstore_1 将float类型值存入局部变量1  
fstore_2 将float类型值存入局部变量2  
fstore_3 将float类型值存入局部变量3  
dstore_0 将double类型值存入局部变量0  
dstore_1 将double类型值存入局部变量1 
dstore_2 将double类型值存入局部变量2  
dstore_3 将double类型值存入局部变量3  
astore_0 将引用类型或returnAddress类型值存入局部变量0  
astore_1 将引用类型或returnAddress类型值存入局部变量1  
astore_2 将引用类型或returnAddress类型值存入局部变量2  
astore_3 将引用类型或returnAddress类型值存入局部变量3  
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类型的局部变量上  

逻辑运算  
移位操作  
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 

线程同步  
montiorenter 进入并获取对象监视器  
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,ldc2_w,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

相关学习路线

JAVA资深架构师成长路线->架构师筑基必备技能->JVM性能深度调优

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值