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

      构造器调用的层次结构带来了一个有趣的两难问题。如果在构造器内部调用正在构造的对象的某个动态绑定方法,此时会出现难以察觉的错误。我们知道,动态绑定的调用是在运行时才决定的,对象无法知道到底调用的是哪个类的方法。当我们在构造器中调用动态绑定的方法,就会用到该方法被覆盖之后的定义。但是这种调用的效果难以预计,因为被覆盖的方法在对象被完全构造之前就会被调用。我们先来看看下面这段代码,是最近看java编程思想时的一段代码:

    具体代码实现:

    class Glyph{
       void draw(){syste.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 RolyConstructors {
       public static void main(string[] args){
       new RoundGlyph(5);
       }
    }

    我们分析一下代码的具体实现过程:
    new RoundGlyph(5);
    1)这段代码运行时会先访问其父类 Glyph的构造函数:
    System.out.println("Glyph() before draw()"); 打印输出
    2)然后draw();会执行被子类RoundGlyph覆写的draw()方法
    此时radius还没有被赋初值,默认为0,因此打印出 RoundGlyph.draw(), radius = 0
    3)继续执行之后的System.out.println("Glyph() after draw()"); 打印输出
    4)父类的构造函数结束,执行本类RoundGlyph的构造函数
    radius = r;
    System.out.println("RoundGlyph.RoundGLyph(), radius = " + radius);
    给radius赋值5,后输出

  • 相关阅读:
    Python_堡垒机开发基础
    用haslib给字符加密
    python学习(集合)
    编码
    小练习03
    python学习(字典)
    小练习02
    python学习(列表,元祖)
    小练习
    python学习
  • 原文地址:https://www.cnblogs.com/ysw-go/p/5404349.html
Copyright © 2011-2022 走看看