构造器内部的多态方法的行为

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

具体代码实现:

 1 class Glyph{
 2    void draw(){syste.out.println("Glyph.draw()");
 3    Glyph(){
 4  
 5     system.out.println("Glyph() before draw()");
 6     draw();
 7     system.out.println("Glyph() after draw()");
 8    }
 9 }
10  
11 class RoundGlyph extends Glyph {
12  
13   private int radius = 1;
14   RoundGlyph(int r){
15  
16     radius = r;
17     system.out.println("RoundGlyph.RoundGLyph(), radius = " + radius);
18   } 
19  
20    void draw(){
21  
22       system.out.println("RoundGlyph.draw(), radius = " + radius);
23    }
24  
25 }
26  
27  
28 public class RolyConstructors {
29    public static void main(string[] args){
30    new RoundGlyph(5);
31    }
32 }

我们分析一下代码的具体实现过程:
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,后输出

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值