JAVA 构建器内部的多形性方法的行为
作者:互联网
abstract class Glyph{
abstract void draw();
Glyph(){
System.out.println("Glyph() before draw()");
draw();
System.out.println("Glyph() after draw()");
}
}
class RoundGlyph extends Glyph{
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 PolyConstructor {
public static void main(String[] args){
new RoundGlyph(5);
}
}
在Glphy中,draw()方法是“抽象的”,所以对它可以被其他方法覆盖。事实上,我们在RoundGlyph中不得不对其进行覆盖。但Glyph构建器会调用这个方法,而且调用会在RoundGlyph.draw()中止。
输出结果是:
Glyph() before draw()
RoundGlyph.draw(), radius= 1
Glyph() after draw()
RoundGlyph.RoundGlyph(), radius= 5
在Glphy的构建器调用draw()时,radius的值甚至不是默认的初始值1,而是0.这是因为本身的RoundGlyph尚未构建,所以radius的初始化也尚未完成。初始化的过程是:
- 在采取其他任何操作之前,为对象分配的存储空间初始化成二进制零。
- 就像前面描述的那样,调用基础类构建器,此时,被覆盖的draw()方法会得到,此时会发现radius的值为0。
- 按照原先声明的顺序调用成员初始化代码。
- 调用衍生类构建器的主题。
如果你想让值为零很简单,
只需要将radius设置为static。
static int radius=1;
标签:多形性,draw,JAVA,System,构建,RoundGlyph,radius,out,Glyph 来源: https://blog.csdn.net/dong24k/article/details/110142720