'深入理解Java虛擬機'2018-04-16

Java Class文件結構:


image.png

u1,u2,u3,u4表示1個,2個,3個,4個字節。
Class文件結構中只有兩種數據類型:無符號數和表,表就相當于是結構體了。

//TestClass.java

package com.ejushang.TestClass;
 public class TestClass implements Super{
     private static final int staticVar = 0;
     private int instanceVar=0;
     public int instanceMethod(int param){
         return param+1;
     }
 }
 interface Super{ }

TestClass.class
00000000h: CA FE BA BE 00 00 00 34 00 18 0A 00 04 00 13 09 ; 漱壕...4........
00000010h: 00 03 00 14 07 00 15 07 00 16 07 00 17 01 00 09 ; ................
00000020h: 73 74 61 74 69 63 56 61 72 01 00 01 49 01 00 0D ; staticVar...I...
00000030h: 43 6F 6E 73 74 61 6E 74 56 61 6C 75 65 03 00 00 ; ConstantValue...
00000040h: 00 00 01 00 0B 69 6E 73 74 61 6E 63 65 56 61 72 ; .....instanceVar
00000050h: 01 00 06 3C 69 6E 69 74 3E 01 00 03 28 29 56 01 ; ...<init>...()V.
00000060h: 00 04 43 6F 64 65 01 00 0F 4C 69 6E 65 4E 75 6D ; ..Code...LineNum
00000070h: 62 65 72 54 61 62 6C 65 01 00 0E 69 6E 73 74 61 ; berTable...insta
00000080h: 6E 63 65 4D 65 74 68 6F 64 01 00 04 28 49 29 49 ; nceMethod...(I)I
00000090h: 01 00 0A 53 6F 75 72 63 65 46 69 6C 65 01 00 0E ; ...SourceFile...
000000a0h: 54 65 73 74 43 6C 61 73 73 2E 6A 61 76 61 0C 00 ; TestClass.java..
000000b0h: 0B 00 0C 0C 00 0A 00 07 01 00 20 63 6F 6D 2F 65 ; .......... com/e
000000c0h: 6A 75 73 68 61 6E 67 2F 54 65 73 74 43 6C 61 73 ; jushang/TestClas
000000d0h: 73 2F 54 65 73 74 43 6C 61 73 73 01 00 10 6A 61 ; s/TestClass...ja
000000e0h: 76 61 2F 6C 61 6E 67 2F 4F 62 6A 65 63 74 01 00 ; va/lang/Object..
000000f0h: 1C 63 6F 6D 2F 65 6A 75 73 68 61 6E 67 2F 54 65 ; .com/ejushang/Te
00000100h: 73 74 43 6C 61 73 73 2F 53 75 70 65 72 00 21 00 ; stClass/Super.!.
00000110h: 03 00 04 00 01 00 05 00 02 00 1A 00 06 00 07 00 ; ................
00000120h: 01 00 08 00 00 00 02 00 09 00 02 00 0A 00 07 00 ; ................
00000130h: 00 00 02 00 01 00 0B 00 0C 00 01 00 0D 00 00 00 ; ................
00000140h: 26 00 02 00 01 00 00 00 0A 2A B7 00 01 2A 03 B5 ; &........?..?
00000150h: 00 02 B1 00 00 00 01 00 0E 00 00 00 0A 00 02 00 ; ..?............
00000160h: 00 00 03 00 04 00 07 00 01 00 0F 00 10 00 01 00 ; ................
00000170h: 0D 00 00 00 1C 00 02 00 02 00 00 00 04 1B 04 60 ; ...............`
00000180h: AC 00 00 00 01 00 0E 00 00 00 06 00 01 00 00 00 ; ?..............
00000190h: 0A 00 01 00 11 00 00 00 02 00 12 ; ...........

分析class文件:

magic: CA FE BA BE
version: 00 00 00 34
cp_count: 00 18
cp[1]: 
    flag: 0A (CONSTANT_Methodref_info 類中方法的符號引用)
    class_index: 00 04
    name_and_type_index: 00 13
cp[2]:
    flag: 09 (CONSTANT_Fieldref_info 字段的符號引用)
    class_index: 00 03
    name_and_type_index: 00 14
cp[3]:
    flag: 07(CONSTANT_Class_info 類或接口的符號引用)
    class_index: 00 15
cp[4]:  
    flag:07
    class_index: 00 16
cp[5]:
    flag: 07
    class_index: 00 17
cp[6]:
    flag: 01(CONSTANT_UTF8_info UTF-8編碼的字符串)
    len: 00 09 
    value: 73 74 61 74 69 63 56 61 72(staticVar)
cp[7]:
    flag: 01
    len: 00 01
    value: 49(I)
cp[8]:
    flag: 01
    len: 00 0D 
    value: 43 6F 6E 73 74 61 6E 74 56 61 6C 75 65(ConstantValue)
cp[9]:
    flag: 03(CONSTANT_Integer_info整形字面量)
    value: 00 00 00 00
cp[0x0A]:
    flag: 01
    len: 00 0B
    value: 69 6E 73 74 61 6E 63 65 56 61 72(instanceVar) 
cp[0x0B]:
    flag: 01
    len: 00 06
    value: 3C 69 6E 69 74 3E(<init>)
cp[0x0C]:
    flag: 01
    len: 00 03
    value: 28 29 56(()I)
cp[0x0D]:
    flag: 01 
    len: 00 04
    value: 43 6F 64 65 (Code)
cp[0x0E]:
    flag: 01
    len: 00 0F
    value: 4C 69 6E 65 4E 75 6D 62 65 72 54 61 62 6C 65 (LineNumberTable)
cp[0x0F]:
    01 00 0E 69 6E 73 74 61 6E 63 65 4D 65 74 68 6F 64 (instanceMethod)
cp[0x10]:
    01 00 04 28 49 29 49 ((I)I) 
cp[0x11]:
    01 00 0A 53 6F 75 72 63 65 46 69 6C 65 (SourceFile)
cp[0x12]:
    01 00 0E 54 65 73 74 43 6C 61 73 73 2E 6A 61 76 61 (TestClass.java)
cp[0x13]:
    flag: 0C (CONSTANT_NameAndType_info 字段和方法的名稱以及類型的符號引用)
    name_index: 00 0B
    type_index: 00 0C
cp[0x14]:
    0C 00 0A 00 07
cp[0x15]:
    01 00 20 63 6F 6D 2F 65 6A 75 73 68 61 6E 67 2F
    54 65 73 74 43 6C 61 73 73 2F 54 65 73 74 43 6C
    61 73 73 (com/ejushang/TestClass/TestClass)
cp[0x16]:
    01 00 10 6A 61 76 61 2F 6C 61 6E 67 2F 4F 62 6A
    65 63 74 (java/lang/Object)
cp[0x17]:
    01 00 1C 
    63 6F 6D 2F 65 6A 75 73 68 61 6E 67 2F 54 65 73
    74 43 6C 61 73 73 2F 53 75 70 65 72 (com/ejushang/TestClass/Super)
access_flags (訪問標志):
    00 21 (ACC_PUBLIC ACC_SUPER)
this_class (CONSTANT_class_info 常量池索引):
    00 03
super_class:
    00 04
interface_count (實現的接口或者父類實現的接口的數量):
    00 01
interfaces[interface_count]:
    00 05
field_count:    
    00 02
fields[1]:
    access_flags: 00 1A
    name_index: 00 06
    destriptor_index: 00 07
    attribute_count: 00 01
    attributes[attribute_count]: 
        attribute_name_index: 00 08
        attribute_len: 00 00 00 02
        constantvalue_index: 00 09
fields[2]:
    access_flags: 00 02
    name_index: 00 0A
    destriptor_index: 00 07
    attribute_count: 00 00 
method_count: 00 02
methods[1]:
    access_flags: 00 01
    name_index: 00 0B
    destriptor_index: 00 0C
    attribute_count: 00 01
    attribute[1]:
        attribute_name_index: 00 0D
        attibute_len: 00 00 00 26
        max_stack: 00 02
        max_locals: 00 01
        code_len: 00 00 00 0A
        code: 2A B7 00 01 2A 03 B5 00 02 B1
        exception_table_len: 00 00
        attribute_count: 00 01
        attribute[1]:
            attribute_name_index: 00 0E
            attribute_len: 00 00 00 0A
            line_number_table_len: 00 02
            line[1]:
                start_pc: 00 00
                line_number: 00 03
            line[2]:
                start_pc: 00 04
                line_number: 00 07
methods[2]:
    access_flags: 00 01
    name_index: 00 0F
    destriptor_index: 00 10
    attribute_count: 00 01
    attibute[1]: 
        attribute_name_index: 00 0D
        attribute_len: 00 00 00 1C
        max_stack: 00 02
        max_locals: 00 02
        code_len: 00 00 00 04
        code: 1B 04 60 AC
        exception_table_len: 00 00
        attribute_count: 00 01
        attibute[1]: 
            attribute_name_index: 00 0E
            attibute_len: 00 00 00 06
            line_number_table_len: 00 01
            line[1]:
                start_pc: 00 00
                line_number: 00 0A
attribute_count: 00 01
attribute[1]:
    attribute_name_index: 00 11
    attribute_len: 00 00 00 02
    sourcefile_index: 00 12                  

常量池是什么東西?常量池存儲字面量和符號引用。字面量包括字符串,final常量的值,以及某個屬性的初始值等。符號引用主要
存儲類和接口的全限定名稱,字段的名稱以及描述符,方法的名稱以及描述符。
常量池中存儲數據類型,字面量和符號引用,字面量就是屬性/方法/類名或者描述符這種字符串,符號引用就是第幾個常量。
常量池的項目包括:


image.png

Class文件結構中有字段表,方法表和屬性表,就是變量,方法,屬性的結構體
屬性表集合:


image.png

Java方法中代碼和字節碼指令怎么轉換?有的指令帶參數有的不帶,帶多少參數都是固定的
假如有方法:

public void f(){
    a+b;
}

假如這個方法對應的字節碼指令是...xxyyzz...,xx是加的指令,xx指令帶有兩個參數,跟著它的yy和zz指令就是它的參數,而yy和zz又有可能指向常量池中的內容。

最后編輯于
?著作權歸作者所有,轉載或內容合作請聯系作者
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發布,文章內容僅代表作者本人觀點,簡書系信息發布平臺,僅提供信息存儲服務。

推薦閱讀更多精彩內容

  • magic num : ca fe ba be minor version: 0...
    數碼資訊站閱讀 624評論 0 50
  • 在《深入理解java虛擬機》一書第6章講到了java的類文件,并且詳情介紹了java的class文件的內容。但是,...
    虎子愛琪琪閱讀 295評論 0 0
  • JAVA序列化機制的深入研究 對象序列化的最主要的用處就是在傳遞,和保存對象(object)的時候,保證對象的完整...
    時待吾閱讀 10,931評論 0 24
  • 引文 像AndroidUtilCode這樣優秀的庫替我管理了工具類,大大提高了我工作的效率,現在工具類終于解放了雙...
    KnifeStone閱讀 852評論 4 5
  • 因為在做 PMO 相關的工作,一直想把PMP 經典書籍:項目管理知識體系指南(PMBOK)第五版放到 Kindle...
    谷大地閱讀 2,169評論 2 0