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

本文揭示了Java中构造器内多态可能导致的两个常见错误:子类构造器覆盖父类draw方法导致默认参数问题,以及在未完全初始化子类时调用方法的潜在问题。通过实例解析,讨论了如何避免这些陷阱以提高代码的稳健性。
摘要由CSDN通过智能技术生成

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);
  }
} /* Output:
Glyph() before draw()
RoundGlyph.draw(), radius = 0
Glyph() after draw()
RoundGlyph.RoundGlyph(), radius = 5
*///:~

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

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

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值