构造器内部的多态方法的行为
2016-04-18 14:27
183 查看
构造器调用的层次结构带来了一个有趣的两难问题。如果在构造器内部调用正在构造的对象的某个动态绑定方法,此时会出现难以察觉的错误。我们知道,动态绑定的调用是在运行时才决定的,对象无法知道到底调用的是哪个类的方法。当我们在构造器中调用动态绑定的方法,就会用到该方法被覆盖之后的定义。但是这种调用的效果难以预计,因为被覆盖的方法在对象被完全构造之前就会被调用。我们先来看看下面这段代码,是最近看java编程思想时的一段代码:
具体代码实现:
我们分析一下代码的具体实现过程:
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,后输出
具体代码实现:
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,后输出
相关文章推荐
- 设计模式学习---(2)
- MFC ComboBox的使用
- Android实现手写签名
- 解压*UC*.rar文件,压缩文件夹命令
- 没事看看
- Android通过注解初始化View
- 南京理工大学第八届程序设计大赛(校外镜像) H 谁才是最强战舰!
- span的属性
- 指针问题
- 表格的隔行变色,实现方法
- 跟王老师学多态(二): 引用变量的强制类型转换
- 【日常吐槽 · 第三期】又坑了自己
- android学习总结
- numpy使用过程中小函数记录
- 日期处理类
- linux驱动头文件说明
- Radio开发新功能
- iOS 中的事件处理
- iOS开发者帐号流程
- eclipse中的.project 和 .classpath文件的具体作用