JVM有一套自己的指令集,当然该指令集不随系统、CPU等改变而改变,该指令集是帮助JVM识别一个java字节码的。现在介绍一种是用Oolong工具将java字节码翻译为类汇编语言Oolong的方法。
首先需要下载Oolong,当然这个挺麻烦的,如果有需要可以到我的github上下载源码。https://github.com/jpbirdy/programming-for-the-jvm
当然,实际只需要一个编译好的jar包就可以了,这里可以下载到http://download.csdn.net/detail/whoisafe/9923112,下载后将Oolong.jar放到jdk的lib目录下,同时添加环境变量的CLASSPATH,添加一条Oolong.jar的路径地址。
然后就可以使用Oolong进行class的反编译了。过程如下
假设存在一个HelloWorld.class文件,在class目录中执行:
在该目录下会产生一个HelloWorld.j文件,用文本编辑器打开该文件可以看到如下内容:
.source Message.java .class public super cn/bugsee/javac/Message .super java/lang/Object .method public <init> ()V .limit stack 1 .limit locals 1 .var 0 is this Lcn/bugsee/javac/Message; from l0 to l5 .line 8 l0: aload_0 l1: invokespecial java/lang/Object/<init> ()V l4: return .end method .method public static main ([Ljava/lang/String;)V .limit stack 2 .limit locals 1 .var 0 is args [Ljava/lang/String; from l0 to l9 .line 10 l0: getstatic java/lang/System/out Ljava/io/PrintStream; l3: ldc "junshan say:Hello world!" l5: invokevirtual java/io/PrintStream/println (Ljava/lang/String;)V .line 11 l8: return .end method
以上就是一个简单的System.out.println("HelloWorld")的汇编代码。
介绍该工具主要可以通过将java代码转变为类汇编代码,去解释一些JVM级别控制的一些问题,例如i++是否线程安全等等。