构造器内部的多态方法的行为(在构造器内调用正在构造的对象的某个动态绑定方法)

初始化的实际过程:

1.在其他任何事物发生之前,将分配给对象的存储空间初始化成二进制的零。
2.先调用基类的构造器。此时,调用被覆盖后的draw()方法(注意这一步是在调用子类RoundGlyph的构造器之前调用的)。由于步骤1,所有此时的radius的值是0。
3.按照声明的顺序调用成员的初始化方法。
4.调用子类的构造器主体。

package com.ran.unit8;
class Glyph{
    void draw(){
        System.out.println("Glyph.draw");
    }
    Glyph(){
        System.out.println("Glyph() before draw()");
        draw();
        System.out.println("Glyph() after 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);
    }
}

因此
要用尽可能简单的方法让对象进入正常的状态。在构造器内唯一能够安全调用的那些方法是基类中的final方法(也适用于private方法,它们自动属于final方法)。因为这些方法不可以被覆盖,可以避免上面的问题出现。

猜你喜欢

转载自blog.csdn.net/lll0101/article/details/88725175