达内广州C++学院|c++培训|广州达内科技C++/C#培训|.NET培训|IT培训|达内广州岗顶中心 达内广州C++学院|c++培训|广州达内科技C++/C#培训|.NET培训|IT培训|达内广州岗顶中心
java程序员
 当前位置:主页 > 高端课程 > java程序员 >

《设计模式之禅》读书笔记-六大设计原则

时间:2020-05-23  来源:未知  作者:广州达内培训

水文一篇,六大设计原则

六大设计原则

六大设计原则

单一职责原则(Single Responsibility Principle,SRP)

定义:应该有且仅有一个原因引起类的变更

意义:

  1. 类的复杂性降低,实现什么职责都有清晰明确的定义
  2. 可读性提高
  3. 可维护性提高
  4. 变更引起的风险降低

使用注意:

  1. 是一种很难衡量的模式,需要根据具体业务来,而不是越细越好
  2. 需要衡量可变因素和不可变因素,以及相关的收益成本比率
  3. 接口一定要做到单一职责,类的设计尽量做到只有一个原因引起变化

里氏替换原则(Liskov Substitution Principle, LSP)

定义:

  1. 如果对每一个类型为S的对象o1,都有类型为T的对象o2,使得以T定义的所有程序P在所有的对象o1都代换成o2时,程序P的行为没有发生变化,那么类型S是类型T的子类型。
  2. 所有引用基类的地方必须能透明地使用其子类的对象

所有引用父类的地方,换成父类的任意子类都可以正常工作

里氏替换原则对继承的规范要求:

  1. 子类必须完全实现父类的方法
  2. 子类可以有自己新的方法
  3. 覆盖或实现父类的方法时输入参数可以被放大(参数类型 范围放大)
  4. .覆写或实现父类的方法时输出结果可以被缩小(返回类型可以为父类方法的子类型)

依赖倒置原则(Dependence Inversion Principle,DIP)

定义:

  1. 高层模块不应该依赖低层模块,两者都应该依赖其抽象
  2. 抽象不应该依赖细节
  3. 细节应该依赖抽象

在java中的表现:

  1. 模块间的依赖通过抽象发生,实现类之间不发生直接的依赖关系,其依赖关系是通过接口或抽象类产生的
  2. 接口或抽象类不依赖于实现类
  3. 实现类依赖接口或抽象类

实质就是面向接口编程

意义:

  1. 可以减少类间的耦合性
  2. 提高系统的稳定
  3. 降低并行开发引起的风险
  4. 提高代码的可读性和可维护性

作者在这里使用了一个司机、宝马、奔驰的例子进行了阐述。

依赖的三种方法:

  1. 构造函数传递依赖对象
  2. setter方法注入依赖对象
  3. 接口声明依赖对象,也叫接口注入(其实就是在调用方法时传入依赖对象)

接口隔离原则(Interface Segregation Principle, ISP)

定义:

  1. 客户端不应该依赖它不需要的接口
  2. 类间的依赖关系应该建立在最小的接口上

建立单一接口,不要建立臃肿庞大的接口。即接口尽量细化,同时接口中的方法尽量少

违背接口隔离原则的坏处:

书中举了一个美女接口,并以美女标准变更说明了将多个方法放到一个接口难以适应变化

接口隔离原则对接口设计规范的要求:

  1. 接口要尽量小
  2. 接口要高内聚
  3. 定制服务
  4. 接口设计是有限度的

迪米特法则(Law of Demeter,LoD)或最少知识原则(Least KnowledgePrinciple,LKP)

定义:

一个对象应该对其他对象有最少的了解

意义:

解耦,方便维护

原则:

  1. 只与直接依赖的对象通信
  2. 对象之间的依赖应该尽可能少的暴露内部细节

开闭原则(Open Close Principle, OCP)

定义:

一个软件实体如类、模块和函数应该对扩展开放,对修改关闭。

开闭原则告诉我们应尽量通过扩展软件实体的行为来实现变化,而不是通过修改已有的代码来完成变化

意义:

有助于构建稳定的、灵活的系统

开闭原则的案例:

书中给出了销售书的一个案例,变化是需要打折,此时如何处理的问题,给出的最优方法是继承原来的书,重写其getPrice方法

使用开闭原则的原因:

开闭原则是最基础的一个原则。其他设计原则都是开闭原则的具体形态,也就是说其他原则就是指导设计的工具和方法,而开闭原则才是其精神领袖

开闭原则的重要性体现:

  1. 开闭原则对测试的影响
  2. 开闭原则可以提高复用性
  3. 开闭原则可以提高可维护性
  4. 面向对象开发的要求

如何使用开闭原则:

  1. 抽象约束
    • 通过接口或抽象类约束扩展,对扩展进行边界限定,不允许出现在接口或抽象类中不存在的public方法
    • 参数类型、引用对象尽量使用接口或者抽象类
    • 抽象层尽量保持稳定,一旦确定即不允许修改
  2. 元数据(metadata)控制模块行为

用来描述环境和数据的数据,通俗地说就是配置参数,参数可以从文件中获得,也可以从数据库中获得

  1. 制定项目章程

  2. 封装变化

    • 将相同的变化封装到一个接口或抽象类中
    • 将不同的变化封装到不同的接口或抽象类中,不应该有两个不同的变化出现在同一个接口或抽象类中



上一篇:HashMap 的 7 种遍历方式与性能分析!(强烈推荐)
下一篇:没有了

友情链接:
  • 全球最大晶圆代工半导体制造厂,台积电斥资订购艾斯摩尔机器设备
  • 英特尔依然是那个英特尔,且看英特尔的城防体系
  • 支持双 DRAM 内存接口,慧荣企业级 SSD 主控方案披露
  • 在全球被反垄断罚款,冤!高通到底哪里得罪了欧盟?
  • 强强联合!万业、微电子所和芯鑫共同打造全新半导体设备
  • 复旦大学校长称:对于集成电路产业发展,大学应该主动担当
  • 技术再升级!无锡中科芯攻克晶圆级再布线及晶圆级凸点制备关键技
  • 聚力!万业企业设立集成电路装备集团,提供自主可控设备
  • 德州仪器C2000微控制器增强连通性和控制性
  • 英特尔打出降价策略,以免被竞争对手 AMD 打败?
  • 贸易摩擦的闹剧没有赢家,苹果有勇气离开中国吗?
  • 图像信号与视觉处理器的发展趋势
  • 真干快消品定位方案班(第二期)火热开班
  • Java集合 ArrayList原理及使用
  • TDD(测试驱动开发)死了吗?
  • JAVA基础之XML相关
  • javaweb项目搭建ehcache缓存系统
  • 每日一码——字符串统计
  • 一篇文章帮你彻底搞清楚“I/O多路复用”和“异步I/O”的前世今生
  • 九:模板方法模式
  • 十二:命令模式(人员解耦和)
  • Java 转PPT为图片、PDF、SVG、XPS、ODP以及PPT和PPTX互转
  • SpringCloud学习(SPRINGCLOUD微服务实战)一
  • 记一次微信网页授权后获取用户信息并重定向
  • 速途新营销五点实战洞察解码“品效合一”
  • 十一:外观模式详解(Service,action与dao)
  • 手把手教你学会 基于JWT的单点登录
  • mysql锁机制总结,以及优化建议
  • 解决多个版本jar包冲突【jar内包名重命名】
  • 中国首张5G终端电信设备进网许可证 华为Mate 20 X 5G版入网
  • RPC之Thrift
  • 高级Java工程师必备 ----
  • 天猫618期间实物支付GMV增长38.5%
  • 换季了,老板你的库存处理好了吗?
  • 从“618”大数据看中国消费新活力
  • 小米生态链:贵在格局感与收放度
  • CODING 2.0 企业级持续交付解决方案
  • 老铁奇趴“新京济” 快手*京东618战报出炉
  • 中小企业新媒体运营基本技能
  • 上汽大通房车再度携手LINE FRIENDS 魔都巡游顺利开启
  • 华为高端手机国内市场份额超苹果夺得榜首
  • 中国智能制造分析报告
  • iPlus艾加营销助力腾讯广告牵手吴晓波 推进商业IP变现
  • 2019世界新能源汽车大会7月1日将在海南举行
  • 区域酒企如何转型突围
  • 时时彩论坛
  • 五星体育斯诺克
  • 北单比分直播
  • 河北11选5走势图
  • 福建体彩36选7开奖结果
  • 九龙图库下载