JAVA设计模式-设计原则(三)里氏代换原则

1.概念

 任何基类可以出现的地方,子类一定可以出现。

子类对象 能够替换程序中父类对象出现的任何地方,并且保证原来程序的逻辑行为不变及正确性不被破坏。

2.为什么使用里氏替换原则

   继承优点
        a 提高代码的重用性,子类拥有父类的方法和属性;
        b 提高代码的可扩展性,子类可形似于父类,但异于父类,保留自我的特性;
继承缺点:侵入性、不够灵活、高耦合
        a 继承是侵入性的,只要继承就必须拥有父类的所有方法和属性,在一定程度上约束了子类,降低了代码的灵活性;
        b 增加了耦合,当父类的常量、变量或者方法被修改了,需要考虑子类的修改,所以一旦父类有了变动,很可能会造成非常糟糕的结果,要重构大量的代码。

因为继承带来的侵入性,增加了耦合性,也降低了代码灵活性,父类修改代码,子类也会受到影响,此时就需要里氏替换原则

3.总结几种违反里氏替换原则的情况:

   a 子类违背父类声明要实现的功能
     父类中提供的 sortOrdersByAmount()函数来按照金额从小到大来给订单排序,而子类重写这个     sortOrdersByAmount()函数之后,是按照创建日期来给订单排序的。那子类的设计就违背里式替换原则。

   b 子类违背父类对输入、输出、异常的约定
父类某个函数约定:运行出错的时候返回 null;获取数据为空的时候返回空集合(empty collection)。而子类重载函数之后运行出错返回异常(exception),获取不到数据返回 null。子类行为发生变化。

  c 父类某个函数约定,输入数据可以是任意整数,但子类实现的时候,只允许输入数据是正整数,不允许负数。子类对输入的数据的校验比父类更加严格,那子类的设计就违背了里式替换原则。

  d 在父类中,某个函数约定只会抛出 ArgumentNullException 异常,那子类的设计实现中只允许抛出 ArgumentNullException 异常,任何其他异常的抛出,都会导致子类违背里式替换原则。

4.注意事项

    子类必须实现父类的抽象方法,但不得重写(覆盖)父类的非抽象(已实现)方法。
    子类中可以增加自己特有的方法。
    当子类覆盖或实现父类的方法时,方法的前置条件(即方法的形参)要比父类方法的输入参数更宽松。
    当子类的方法实现父类的抽象方法时,方法的后置条件(即方法的返回值)要比父类更严格

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

mhi()

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值