在遇到一些小问题的时候我们经常会使用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中的"+"操作过程了. 相信有了它,对以后的学习一定会有很大的帮助~