编程语言
首页 > 编程语言> > JAVA 构建器内部的多形性方法的行为

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的初始化也尚未完成。初始化的过程是:

  1. 在采取其他任何操作之前,为对象分配的存储空间初始化成二进制零。
  2. 就像前面描述的那样,调用基础类构建器,此时,被覆盖的draw()方法会得到,此时会发现radius的值为0。
  3. 按照原先声明的顺序调用成员初始化代码。
  4. 调用衍生类构建器的主题。
    如果你想让值为零很简单,
    只需要将radius设置为static。
static int radius=1;

标签:多形性,draw,JAVA,System,构建,RoundGlyph,radius,out,Glyph
来源: https://blog.csdn.net/dong24k/article/details/110142720