提出问题:已知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