提出问题:已知B类继承于A类,且B类复写了A类中公共的非静态的function()方法。且在A类的构造器中,调用function()方法。我们知道,在创建B类实例对象的时候,会调用A类的构造器方法。那么,调用的是B类实例对象的function()方法,还是A类实例的function()方法?
首先,看一个实例:
class Glyph {
Glyph(){
System.out.println("Glyph() before draw()");
draw();
System.out.println("Glyph() after draw()");
}
void draw() {
System.out.println("Glyph.draw()");
}
}
class RoundGlyph extends Glyph {
private int radius = 1;
RoundGlyph(int r) {
radius = r;
System.out.println("RoundGlyph.RoundGlyph().radius = " + radius);
}
void draw() {
System.out.println("RoundGlyph.draw().radius = " + radius);
}
}
public class PolyConstructors {
public static void main(String[] args) {
new RoundGlyph(5);
}
}
父类Glyph有非静态方法draw(), 子类RoundGlyph复写了draw()方法。且父类Glyph构造器中调用了draw()方法。
分析:
1. 在调用Glyph构造器时,子类对象RoundGlyph还未生成。但是,这里的draw()方法依然属于动态绑定方法(即后期绑定),所以调用的还是子类的draw()方法,不是父类的
2. 在其他事物发生之前,将分配给对象的存储空间初始化为二进制的零,在本例中,虽然子对象RoundGlyph还没有构建成功,但是,其非静态成员变量,会初始为0,不是1(1是后期进行子类初始化的时候才赋的值,但此时子类对象尚未初始化)
运行结果:
Glyph() before draw()
RoundGlyph.draw().radius = 0
Glyph() after draw()
RoundGlyph.RoundGlyph().radius = 5