设计原则
太郎.
这个作者很懒,什么都没留下…
展开
-
【笔记】合成(组合/聚合)复用原则
合成(组合/聚合)复用原则 定义 尽量使用对象组合,聚合,而不是继承关系达到软件复用的目的 聚合has-A的关系,组合是contains-A的关系,继承是is-A的关系 优点 可以使系统更加灵活,降低类与类之间的耦合度,一个类的变化对其他类造成的影响相对较少 代码示例 /** * 合成(组合/聚合)复用原则 */ public class Composition { public static void main(String[] args) { ProductD原创 2020-06-06 18:23:17 · 278 阅读 · 0 评论 -
【笔记】里式替换原则
里式替换原则 定义 如果每一个类型为T1的对象o1,都有类型为T2的对象o2,使得以T1定义的所有程序P在所有对象o1都替换成o2时,程序p的行为没有发生任何变化,那么类型T2是类型T1的子类型 一个软件实体适用于一个父类的话,那一定适用于其子类,所有引用父类的地方必须能够透明地使用其子类的对象,子类对象能够替换父类对象,而程序逻辑不变 子类可以扩展父类的功能,但是不能改变父类原有的功能 子类可以实现父类的抽象方法,但是不能覆盖父类的非抽象方法 子类中可以增加自己特有的方法 子类的方原创 2020-06-06 17:52:54 · 150 阅读 · 0 评论 -
【笔记】迪米特原则
迪米特原则 定义 一个对象应该对其他对象保持最少的了解,又叫最少知道原则 尽量降低类与类之间的耦合 强调只和朋友交流,不和陌生人说话 朋友 出现在成员变量,方法的输入,输出参数中的类称为成员朋友类,而出现在方法体内部的类不属于朋友类 优点 降低类之前的耦合 代码示例 import java.util.ArrayList; import java.util.List; /** * 迪米特原则 */ public class demeter { public static原创 2020-05-31 18:08:06 · 105 阅读 · 0 评论 -
【笔记】接口隔离原则
接口隔离原则 ** 定义** 用多个专门的接口,而不是使用单一的总接口,客户端不应该依赖它不需要的接口 一个类对一个类的依赖应该建立在最小的接口上 建立单一接口,不要建立庞大臃肿的接口 尽量细化接口,一个接口中的方法尽量少 适度原则,一定要适度(最重要的点) 优点 符合我们常说的高内聚,低耦合的设计思想,从而使得类具有很好的可读性,可扩展性和可维护性 代码示例 /** * 接口隔离原则 */ public class Interface { } /** * 动物行为,此种定义会存在许多空实现原创 2020-05-31 17:41:54 · 195 阅读 · 0 评论 -
【笔记】单一职责原则
单一职责原则 定义 不要存在多于一个导致类变更的原因 一个类,接口,方法只负责一项职责 优点 降低类的复杂度,提高类的可读性,提高系统的可维护性,降低变更引起的风险 代码示例 /** * 单一职责原则 */ public class SingleResponse { public static void main(String[] args) { // Bird bird = new Bird(); // bird.mainMoveMode("大雁"); /原创 2020-05-31 17:16:04 · 149 阅读 · 0 评论 -
【笔记】依赖倒置原则
依赖倒置原则 定义 高层模块不应该依赖底层模块,二者都应该依赖其抽象 抽线不应该依赖细节,细节应该依赖于抽象 针对接口编程,而不是针对实现编程 优点 可以减少类之间的耦合性,提高系统的稳定性,提高代码的可读性和维护性,可降低修改程序所造成的风险 代码示例 /** * 依赖倒置原则 */ public class Dependent { public static void main(String[] args) { Jack jack = new Jack();原创 2020-05-30 22:25:38 · 63 阅读 · 0 评论 -
【笔记】开闭原则
开闭原则(非常重要的原则) 定义 一个软件实体如类,模块和函数应该对扩展开放,对修改关闭 用抽象构建框架,用实现扩展细节 优点 提高软件系统的可复用性,可维护性 核心思想 面向抽象编程,当有新的功能时应该不需要修改之前的代码,而是新增 代码示例 /** * 开闭原则 */ public class OpenClose { public static void main(String[] args) { Course course = new JavaDiscount原创 2020-05-30 21:45:54 · 107 阅读 · 0 评论