在遇到一些小问题的时候我们经常会使用Javap反编译取得字节码来分析,虽然Javap能完成这个工作,但是有两个缺点,一方面操作麻烦,需要很多步骤,一方面没有文档注释,对新手来说看起字节码来比较麻烦。
这里推荐一个工具,Bytecode Outline .它是Eclipse的插件,可以把当前的正在编辑Java的文件或者class文件直接显示出其相应的字节码出来,而且可以进行两个Java文件的字节码比较或者两个class文件的字节码比较或一个Java文件与一个class文件进行字节码的比较。
安装方法:和其它插件类似,可以拷贝到plugin下也可以link方式安装
下载地址:http://forge.objectweb.org/projects/asm/
注意:因为Bytecode Outline的运行需要ASM Framework,所以也要下载这个文件
对应的两个文件名为:
org.objectweb.asm_2.2.2.jar
de.loskutov.BytecodeOutline_2.1.0.jar
也可以用update的方式来安装,好处是可以随时更新,地址如下:
http://download.forge.objectweb.org/eclipse-update/
试了一下,不知道什么原因,第一种方法失败,只有使用第二种方法了,不过也很方便,在eclipse下安装.点击help->software update->find and install... 后面的就按一步步安装就可以了.
安装完了,windows-->showview-->other-->点开Java的树-->选择Bytecode ,同样的方法选择Bytecode Reference .下面看一个典型的String的反编译例子:
public static void main(String[] args){
String m="mango";
String s="abc"+m+"def"+47;
System.out.println(s);
}
反编译后:
// access flags 9
public static main(String[]) : void
L0 (0)
LINENUMBER 6 L0
LDC "mango"
ASTORE 1: m
L1 (3)
LINENUMBER 7 L1
NEW StringBuilder
DUP
LDC "abc"
INVOKESPECIAL StringBuilder.<init>(String) : void
ALOAD 1: m
INVOKEVIRTUAL StringBuilder.append(String) : StringBuilder
LDC "def"
INVOKEVIRTUAL StringBuilder.append(String) : StringBuilder
BIPUSH 47
INVOKEVIRTUAL StringBuilder.append(int) : StringBuilder
INVOKEVIRTUAL StringBuilder.toString() : String
ASTORE 2: s
L2 (16)
LINENUMBER 8 L2
GETSTATIC System.out : PrintStream
ALOAD 2: s
INVOKEVIRTUAL PrintStream.println(String) : void
L3 (20)
LINENUMBER 9 L3
RETURN
L4 (22)
LOCALVARIABLE args String[] L0 L4 0
LOCALVARIABLE m String L1 L4 1
LOCALVARIABLE s String L2 L4 2
MAXSTACK = 3
MAXLOCALS = 3
通过反编译后的字节码,我们就会更加深刻理解String中的"+"操作过程了.
相信有了它,对以后的学习一定会有很大的帮助~