黑马程序员技术交流社区

标题: JVM学习序列之二:Java Class文件结构分析 [打印本页]

作者: 荣凯旋    时间: 2012-1-28 13:01
标题: JVM学习序列之二:Java Class文件结构分析
CONSTANT_Integer

            CONSTANT_Integer_info {

                     u1 tag;        //tag 值等于 3

                    u4 bytes;// 按照高位在前格式存储 int 类型值

            }

CONSTANT_Float

           CONSTANT_Float_info {

                    u1 tag;   //tag 值等于 4

                    u4 bytes;

           }

CONSTANT_Long

            CONSTANT_Long_info {

                    u1 tag;    //tag 值等于 5

                    u4 high_bytes;

                    u4 low_bytes;

             }   

CONSTANT_Double

           CONSTANT_Double_info {

                    u1 tag;   //tag 值等于 6

                    u4 high_bytes;

                     u4 low_bytes

           }

CONSTANT_Class ( 类全限定名 )

        CONSTANT_Class_info {

                u1 tag;             //tag=7

                u2 name_index; // 指向包含全限定名字符串的一个 CONSTANT_Utf8_info

        }

CONSTANT_String

           CONSTANT_String_info {

                    u1 tag; //tag=8

                    u2 string_index;// 包含文字字符串的 CONSTANT_Utf8_info 表索引

            }

  

        

CONSTANT_Fieldref

          CONSTANT_Fieldref_info {

                    u1 tag;    //tag=9

                    u2 class_index;  //constant_pool 的索引,对应 CONSTANT_Class_info

                    u2 name_and_type_index;//constant_pool 的索引,对应 CONSTANT_NameAndType_info

          }

CONSTANT_Methodref

           CONSTANT_Methodref_info {

                    u1 tag; //tag=10

                    u2 class_index;

                    u2 name_and_type_index;

           }

  CONSTANT_InterfaceMethodref

           CONSTANT_InterfaceMethodref_info {

                    u1 tag; //tag=11

                    u2 class_index;

                     u2 name_and_type_index;

           }

CONSTANT_NameAndType

            CONSTANT_NameAndType_info {

                    u1 tag; //tag=12

                    u2 name_index;

                    u2 descriptor_index;

            }

  

access_flags 意义如下 :

ACC_PUBLIC     0x0001  

        ACC_FINAL      0x0010  

        ACC_SUPER      0x0020  

        ACC_INTERFACE  0x0200  

        ACC_ABSTRACT   0x0400  

this_class: constant_pool 中的索引值 , 指向的元素的 cp_info 等价为 CONSTANT_Class_info

CONSTANT_Class_info {

u1 tag; // 必须为 CONSTANT_Class (7)

u2 name_index; // 为指向 constant_pool 中的一个索引值

}

name_index : 指向的元素的 cp_info 等价为 CONSTANT_Utf8_info

field_info {

u2 access_flags; // 访问控制权

u2 name_index; //constant_pool 中的索引,对应于 CONSTANT_Utf8_info 描述。

u2 descriptor_index; //constant_pool 中的索引,对应于 CONSTANT_Utf8_info 描述。

u2 attributes_count;

attribute_info attributes[attributes_count]; //attribute_info 将在 mothods 后描述。

}

field_info 中 access_flages 意义如下 :

ACC_PUBLIC 0x0001

ACC_PRIVATE 0x0002

ACC_PROTECTED 0x0004

ACC_STATIC 0x0008

ACC_FINAL 0x0010

ACC_VOLATILE 0x0040

ACC_TRANSIENT 0x0080

  

其中很显然不能同时为 ACC_FINAL 和 ACC_VOLATILE ; 且前三项是互斥的。

interface 必须置 ACC_PUBLIC, ACC_STATIC,ACC_FINAL 位,且不能置其他位。

其他未指明的位保留将来使用,并且编译器应当将其置为 0 ,同时 Java 虚拟机应当忽略他们。

  

methods 指明了类中的所有方法。

method_info {

u2 access_flags;

u2 name_index; // 指向 constant_pool 的入口,对应为 CONSTANT_Utf8_info

u2 descriptor_index; // 指向 constant_pool 的入口,对应为 CONSTANT_Utf8_info

u2 attributes_count;

attribute_info attributes[attributes_count];

// 此处只能出现 Code 、 Exceptions 、 Synthetic 、 Deprecated 四种类型的属性

}

access_flags 访问权描述如下 :

ACC_PUBLIC        0x0001

            ACC_PRIVATE       0x0002

            ACC_PROTECTED     0x0004

            ACC_STATIC        0x0008

            ACC_FINAL         0x0010

            ACC_SYNCHRONIZED  0x0020

            ACC_NATIVE        0x0100

            ACC_ABSTRACT      0x0400

            ACC_STRICT        0x0800  

  

attribute_info {

u2 attribute_name_index; //constant_pool 中的索引,对应于 CONSTANT_Utf8_info 描述。

u4 attribute_length;

u1 info[attribute_length];

}

现在已经预定义的属性有 :

1. SourceFile : attribute_info 被替代为 :

SourceFile_attribute {

u2 attribute_name_index;

u4 attribute_length;

u2 sourcefile_index; // 指向 constant_pool 中的一个 CONSTANT_Utf8_info 结构。

}

2. ConstantValue : attribute_info 被替代为 :

ConstantValue_attribute {

u2 attribute_name_index;

u4 attribute_length; // 必须为 2

u2 constantvalue_index;

}

对于 constantvalue_index 意义如下 :

long CONSTANT_Long

float CONSTANT_Float

double CONSTANT_Double

int, short, char, byte, boolean CONSTANT_Integer

String CONSTANT_String

ConstantValue 用于 field_info 中,用于描述一个 static 常量 ,

且此时 field_info 的 access_flags 应为 ACC_STATIC

3. Code : attribute_info 被替代为 :

Code_attribute {

u2 attribute_name_index;

u4 attribute_length;

u2 max_stack; // 执行此函数时可用的栈的最大深度

u2 max_locals; // 执行此函数可用到的最大本地变量数目,包括参数。

// 注意 : 一个 long/double 相当于 2 个变量数目 .

u4 code_length; // 本函数用到的代码长度。

u1 code[code_length]; // 实现本函数的真正字节码

u2 exception_table_length;

{ u2 start_pc;

u2 end_pc; // 捕获违例时执行代码数组中的 [start_pc, end_pc) 部分

u2 handler_pc; // 现在还不大明白他是干嘛的 !!

u2 catch_type; // 指向 constant_pool 的索引,对应 CONSTANT_Class_info

}exception_table[exception_table_length];

u2 attributes_count;

attribute_info attributes[attributes_count];

}

CONSTANT_Class_info {

u1 tag; // 必须为 CONSTANT_Class (7)

u2 name_index; // 不用我再说了吧 ?

}

  






欢迎光临 黑马程序员技术交流社区 (http://bbs.itheima.com/) 黑马程序员IT技术论坛 X3.2