在Java中,继承是一个非常重要的特性,因此我们常常会定义一个基类再去继承它。但有一个我们一直没有关注的一个问题:对基类进行修改会导致子类不正确的行为,这就是所谓的脆弱的基类问题,因为基类代码的修改不再符合在其子类中的假设。如果基类没有提供子类应该怎么实现的明确规则(哪些方法需要被重写及如何重写),当事人可能会有按基类作者预期之外的方式来重写方法的风险。因为可能分析所有的子类,这种情况下基类是如此“脆弱”,任何修改都有可能导致子类出现预期之外的行为改变。
为了防止这种问题,作为优秀Java编程风格最为知名的图书之一《Effective Java》建议你“要么为继承做好设计并记录文档,要么禁止这么做”。这意味着所有没有特别需要在子类中被重写的类和方法应该被显示的标注为final。