本文示范了一种反编译Java字节码的方法,首先通过解析class文件,然后将解析的结果转成java代码。但是本文并没有覆盖所有的class文件的特性和指令,只针对部分规范进行解析。

所有的代码代码都是示范性的,追求功能实现,没有太多的软件工程方面的考量。

Class文件格式

一个Java类或者接口被javac编译后会生成一个class文件,class文件可以用下面代码来描述,u2,u4分表表示2个字节的无符号数和4个字节的无符号数。

    ClassFile {        u4 magic;        u2 minor_version;        u2 major_version;        u2 constant_pool_count;        cp_info constant_pool[constant_pool_count-1];        u2 access_flags;        u2 this_class;        u2 super_class;        u2 interfaces_count;        u2 interfaces[interfaces_count];        u2 fields_count;        field_info fields[fields_count];        u2 methods_count;        method_info methods[methods_count];        u2 attributes_count;        attribute_info attributes[attributes_count];
    }