1.      

如果一个类没有显式继承自Object,则会自动为其加上继承自Object

以如下代码为例

 Java Code 

1
2
3
4

 

package com.test.a;

public class Test {
}

 

class文件结构[1] 编译前预处理

 

2.      

在创建一个对象时,必须先创建他的父对象。

所以在构造函数中(如果没有显式写构造函数则会自动添加构造函数),必须先调用父类的构造函数。如果没有显式调用,则会自动为其加上调用父类默认的构造函数

以如下代码为例

 Java Code 

1
2
3
4
5
6

 

package com.test.b;

public class Test {
    
public Test(){
    }
}

 class文件结构[1] 编译前预处理

 

 Java Code 

1
2
3
4

 

package com.test.c;

public class Test extends TestParent{
}

 class文件结构[1] 编译前预处理

 

3.      

成员变量的预处理见下一篇

但是还有一个地方需要注意,当在一个类中引用另一个类的public static final类型常量时

以如下代码为例

 Java Code 

1
2
3
4
5

 

package com.test.e;

public class TestA{
    
public static final double m1=100d;
}

 

 Java Code 

1
2
3
4
5
6
7
8

 

package com.test.e;

public class TestB {
    
public void method1(){
        
double v1=TestA.m1;
        System.out.println(v1);
    }
}

TestB中引用TestA的常量m1,但是TestB.class字节码文件中并不会引用TestA,而是在自己的常量池中添加一个相同类型的常量池项,使用时直接引用自己的常量池项

意即并不会使用到TestA,后面会讲到,并不会触发去加载TestA

class文件结构[1] 编译前预处理

class文件结构[1] 编译前预处理

4.      

在成员方法中(包括构造函数),如果局部变量只定义,未进行初始化,后续也未赋值使用,则会被删除掉。

以如下代码为例

 Java Code 

1
2
3
4
5
6
7
8
9
10
11

 

package com.test.d;

import java.util.Date;

public class Test {
    
public void method1(){
        
double v1;
        
double v2=200;
        Date v3;
    }
}

可以看到局部变量表中并没有v1v3

 class文件结构[1] 编译前预处理

并且常量池中也没有相关的变量名称和描述符(因为局部变量表中都没有)

 class文件结构[1] 编译前预处理

5

字符串类型的处理见单独章节

相关文章:

  • 2021-07-29
  • 2021-07-21
  • 2022-12-23
  • 2021-11-30
  • 2022-12-23
  • 2022-12-23
  • 2022-12-23
猜你喜欢
  • 2021-05-08
  • 2022-12-23
  • 2022-12-23
  • 2021-10-30
  • 2021-07-02
  • 2022-12-23
  • 2022-02-05
相关资源
相似解决方案