zoukankan      html  css  js  c++  java
  • 构造器内部的多态方法的行为

    每天发出自己学习的内容,坚持坚持。。。

    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 构造器内部的多态方法的行为
    {
    public static void main(String[] args)
    {
    new RoundGlyph(5);
    }

    }
    /**

    输出:

    Glyph() before draw()
    RoundGlyph.draw(),radius=0
    Glyph() after draw()
    RoundGlyph.RoundGlyph(),radius=5


    基类Glyph的构造器中调用了被子类RoundGlyph覆盖的draw()方法,并且输出了radius=0,这显然是一个错误,因为这个"0"是在其他任何事物发生之前,
    系统分配给对象的储存空间的初始值--二进制的零,而非我们想要设定的初始值"1",这是因为,我们在创建子类(RoundGiyph)对象时会先调用基类(Glyph)
    的构造器构造基类对象,而在基类的构造器中却调用了被子类覆盖的动态绑定的方法(draw()),而这个方法所操作的可能是子类中的还未进行初始化的成员(radius)
    ,这便会招致灾难,尽管编译器并没有报错。
    在构造器中,唯一能够安全调用的是基类中的final方法(包括private方法),因为这些方法不能被子类覆盖,也就不会出现上述的问题
    */

  • 相关阅读:
    狄利克雷卷积
    洛谷P2044 [NOI2012]随机数生成器
    Miller Rabin算法详解
    BZOJ3667: Rabin-Miller算法
    洛谷P3383 【模板】线性筛素数(Miller_Rabin)
    洛谷P3806 【模板】点分治1
    BZOJ1468: Tree
    Android Camera调用过程分析
    安卓开发37:自定义的HorizontalScrollView类,使其pageScroll的时候焦点不选中
    Android抖动动画
  • 原文地址:https://www.cnblogs.com/fanzhengzheng/p/7476255.html
Copyright © 2011-2022 走看看