栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > Java

Java构造器内的多态行为 易错

Java 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

Java构造器内的多态行为 易错

Java构造器内的多态行为 易错

直接通过例子来看

class Glyph {
  void draw() { print("Glyph.draw()"); }
  Glyph() {
    print("Glyph() before draw()");
    draw();
    print("Glyph() after draw()");
  }
}	

class RoundGlyph extends Glyph {
  private int radius = 1;
  RoundGlyph(int r) {
    radius = r;
    print("RoundGlyph.RoundGlyph(), radius = " + radius);
  }
  void draw() {
    print("RoundGlyph.draw(), radius = " + radius);
  }
}	

public class PolyConstructors {
  public static void main(String[] args) {
    new RoundGlyph(5);
  }
} //:~

这个结果有两个坑
1.首先是父类Glyph().draw()方法被子类的draw()方法覆盖
main函数实例化RoundGlyph对象,会先初始化其父类,调用其父类的构造器
其中父类Glyph().draw()方法被子类的draw()方法覆盖,但输出的radis的值不是1而是0
2.其次,虽然是调用了子类的方法,但子类还没初始化,子类的变量都是默认初始值
因为当调用父类的draw()时被子类覆盖时,子类还没有被初始化,此时的radis默认值是0

因此,在编写构造器的时候,尽量避免调用其他方法,除非是final和private方法,他们不能被覆盖,是安全的

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/774584.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号