开闭原则(Open-Closed Principle)里氏替换原则
开闭原则(Open-Closed Principle)
开闭原则是面向对象的可复用设计的第一块基石。
What 什么是开闭原则?
定义:软件实体应当对扩展开放、对修改关闭。
在定义当中,软件实体可以是一个软件模块、一个由多个类组成的局部结构或者一个独立的类。开闭原则就是指软件实体尽量在不修改原有代码的情况下进行扩展。
Why 为什么要使用开闭原则和When 什么时候使用开闭原则?
任何软件都需要面临一个很重要的问题,随着软件的需求会随着时间的推移而发生变化,
当系统软件面对各种个样的变化,它的系统架构应当是稳定的。如果一个软件符合开闭原则,那么当它面对这些变化的时候,进行需求的扩展的时候不用修改原有的代码。那么使得系统软件,在有用灵活性的同时具有良好的稳定性和延续性。随着软的的规模越来越大、软件的寿命越来越长、软件维护的成本也越来越高,设计满足符合开闭原则的软件,也也来越重要。
How 如何运用开闭原则?
为了满足开闭原则,需要对系统进行抽象化设计,抽象化时开闭原则的关键。
在java语言中,可以为系统定义一个相对稳定的抽象层,而将具体的实现行为,移动到具体的实现层中实现。
在很多面型对象程序设计语言中都提供了抽象类,接口,可以通过他们定义系统的抽层,再通过具体的子类进行扩展。如果需要修改系统的行为,不需要对抽象层进行修改,只需要增加新的具体类类实现新的业务功能。实现在不修改已有代码的基础上扩展系统功能,达到开闭原则的要求。
里氏替换原则(Liskov Substitution Principle)
实现里氏替换原则的前提是实现继承。
What 什么是里氏替换原则
里氏替换的定义
1.原始定义:如果对每一个类型为S的对象o1都有类型为T的对象o2,使得以T定义的所有程序P在所有的对象o1都代换o2是程序P的行为没有变化,那么类型S是T类型的子类。
另一个通俗的定义:所有引用基类的地方必须能够透明地使用子类的对象。
Why为什么要使用里氏替换?
里氏替换是实现开闭原则的方式之一。
How 如何使用里氏替换原则?
由于在使用基类对象的地方都可以使用子类对象,因此在程序中尽量使用基类类型来对子类对象进行定义,而在运行的时候再确定其子类类型,用子类来替换父类对象。
在运用里氏替换原则时应该将父类设计为抽象类或者接口,让子类继承父类或实现接口,并实现在父类中声明的方法,在运行时子类实例替换父类实例,可以很方便地扩展系统的功能,无需修改原有子类的代码,增加新的功能可以通过增加一个新的子类来实现。