七大软件设计原则
一、 开闭原则:(面向对象的最基础原则)
定义:一个软件实体如类,模块和函数应该对扩展开放,对修改关闭。用抽象构建框架,用实现扩展细节。
优点:提高软件系统的可复用性及可维护性。
当变更发生时,不要直接修改类,通过继承扩展的方式完成变更。
举例:超市商品打折(商品原价(Price)是原始类,打折后的商品价格(DiscountPrice)通过继承商品原价(Price)原始类后,在打折后的商品价格类(DiscountPrice)对商品价格进行打折操作)
二、 依赖倒置原则:
定义:设计代码结构时,高层模块不应该依赖低层模块,二者都应该依赖其抽象。
定义补充:抽象不应该依赖细节,细节应该依赖抽象。
针对接口编程,不要针对实现编程。
优点:减少类间的耦合性、提高系统稳定性,提高代码可读性和维护性,可降低修改编程所造成的风险。
举例:
Jane要买一套护肤品(包含精华水、乳液、面霜)。这里“买”的动作是一致的,买精华水,买乳液,买面霜。
创建一个“买”的Java接口(IBuy),创建买的方法(void buy(););
首先是买精华水,创建OneLeafBuy类,继承(implements)IBuy,实现买精华水的操作。
然后买乳液(EmulsionBuy)类,继承(implements)IBuy,实现买乳液的操作。
最后买面霜(FaceCreamBuy),继承(implements)IBuy,实现买乳液的操作。
三个实现类实现后,创建JaneBuy类,首先创建个参数(private IBuy ibuy)通过构造方法传进来IBuy ibuy参数,声明个通用的“买”(void buy)方法,调用 ibuy.buy();
创建Test类,在main主方法中new一个JaneBuy类,传入想要买的东西(如 JaneBuy janeBuy = new JaneBuy(new OnLeafBuy);),然后调用其中的买(janeBuy .buy();)的方法
(PS:这个是基于构造方法实现的,可以尝试别的方法实现。)
三、 单一职责原则:
定义:不要存在多余一个导致类变更的原因,就一个类而言,应该只存在一个导致其变更的原因。
优点:降低类的复杂度、提高类的可读性、提高系统的可维护性、降低变更引起的风险。
总结来说,就是一个类、一个接口、或者一个方法只负责一项职责。
四、 接口隔离原则:
定义:用多个专门的接口,而不是使用单一的总接口,客户端不应该依赖它不需要的接口
注意:
一个类对应一个类的依赖应该建立在最小的接口上
建立单一接口,不要建立庞大臃肿的接口
尽量细化接口,每个接口中的方法尽量少
适度原则,一定要适度,否则会造成类爆炸
优点:符合我们常说的高内聚低耦合的设计思想,从而使类具有很好的可读性,可扩展性和可维护性
五、 迪米特法则:
定义:一个对象应该对其他对象保持最少的了解,又叫最少知道原则。
优点:降低类与类之间的耦合。
六、 里氏替代原则:
定义:如果对每一个类型为T1的对象o1,都有类型为T2的对象o2,使得以T1定义的所有程序P在所有的对象o1都替换成o2时,程序P的行为没有发生变化,那么类型T2是类型T1的子类型。
定义扩展:可以理解为一个软件实体如果使用一个父类的话,那一定适用于其子类,所有引用父类的地方肯定能够透明的使用其子类的对象,子类对象能够替换父类的对象,而程序逻辑不变。
引申意义:子类可以扩展父类的功能,但不能改变父类原有的功能。
含义1:子类可以实现父类的抽象方法,但不能覆盖父类的非抽象方法。
含义2:作为父类的子类,可以增加自己特有的方法。
含义3:当子类的方法重载父类的方法时,方法的前置条件(即方法的输入参数)要比父类方法的输入参数更宽松。
含义4:当子类的方法实现父类的方法时(重写、重载或实现抽象方法),方法的后置条件(即方法的输出、返回值)要比父类更严格或相等。
优点:约束继承泛滥,开闭原则的一种体现。加强程序的健壮性,同时变更时也可以做到非常好的兼容性。提高程序的维护性,扩展性。降低需求变更时引入的风险。
七、 合成复用原则:(又叫组合复用原则、聚合复用原则)
定义:编写代码时尽量适用对象组合/聚合,而不是继承关系达到软件复用的目的。
聚合has-a(例如:电脑和U盘,可以单独存在,也可以聚合在一起)
组合contains-a(例如:人体和骨骼、肌肉、组织、器官是组合关系,缺一不可)
继承is-a(例如:狗和金毛犬,有非常强的关联关系)
优点:可以使系统更加灵活,降低类与类之间的耦合度
一个类的变化对其他类造成的影响相对较少。
自己的小总结:
解耦的过程就是将一个大功能中的小功能通过类的形式展示出来,再通过类和接口之间的调用实现功能。
实际开发中,是不可能遵守所有的设计原则的,因为本身很多设计原则是相互之间是有冲突的。设计原则实际上来说是一种指导思想,在实际的开发中,我们可以根据实际情况,在尽可能的遵守设计原则去开发系统功能,方便之后对系统功能的维护和扩展。
文章知识点与官方知识档案匹配,可进一步学习相关知识Java技能树首页概览92560 人正在系统学习中
声明:本站部分文章及图片源自用户投稿,如本站任何资料有侵权请您尽早请联系jinwei@zod.com.cn进行处理,非常感谢!