package com.lu.test;
import static lu.utils.Print.*;
/*
* 在任何构造器内部,整个对象可能只是部分形成——我们只知道基类对象已经进行初始化。
* 如果构造器只是在构建对象过程中的一个步骤,并且该对象所属的类是从这个构造器所属
* 的类导出的,那么导出部分在当前构造器正在被调用的时刻仍旧是没有被初始化的。然而,
* 一个动态绑定 的方法调用却会向外深入到继承层次结构内部,他可以调用导出类的方法。
* 如果我们在构造器内部这么做,那么就可能会调用某个方法,而这个方法所操作的成员可
* 能还未进行初始化。*/
class Glyph{
void draw(){print("Glyph.draw()");}
Glyph(){
print("Glyph() before draw()");
draw();
print("Glyph() after draw()");
}
}
class RoundGlyph extends Glyph{
private int radius=1;
RoundGlyph(int r){
radius=r;
print("RoundGlyph.RoundGlyph(), radius="+radius);
}
void draw(){print("RoundGlyph.draw(), radius="+radius);}
}
public class PolyConstructors {
public static void main(String[] args){
new RoundGlyph(5);
}
import static lu.utils.Print.*;
/*
* 在任何构造器内部,整个对象可能只是部分形成——我们只知道基类对象已经进行初始化。
* 如果构造器只是在构建对象过程中的一个步骤,并且该对象所属的类是从这个构造器所属
* 的类导出的,那么导出部分在当前构造器正在被调用的时刻仍旧是没有被初始化的。然而,
* 一个动态绑定 的方法调用却会向外深入到继承层次结构内部,他可以调用导出类的方法。
* 如果我们在构造器内部这么做,那么就可能会调用某个方法,而这个方法所操作的成员可
* 能还未进行初始化。*/
class Glyph{
void draw(){print("Glyph.draw()");}
Glyph(){
print("Glyph() before draw()");
draw();
print("Glyph() after draw()");
}
}
class RoundGlyph extends Glyph{
private int radius=1;
RoundGlyph(int r){
radius=r;
print("RoundGlyph.RoundGlyph(), radius="+radius);
}
void draw(){print("RoundGlyph.draw(), radius="+radius);}
}
public class PolyConstructors {
public static void main(String[] args){
new RoundGlyph(5);
}
}
output:
Glyph() before draw()
RoundGlyph.draw(), radius=0
Glyph() after draw()
RoundGlyph.RoundGlyph(), radius=5
观察:
Glyph.draw() 方法将要被覆盖,这种覆盖是在RoundGlyph中发生的。但是Glyph构造器会调用这个方法,结果导致了对RoundGlyph.draw()的调用。
但是,当Glyph的构造器调用draw()方法时,radius不是默认初始值1,而是0.