(一)代理
场景:当一个类的某些功能需要由别的类来实现,但是又不确定具体会是哪个类实现。
❗️优势:解耦合
敏捷原则:开放-封闭原则
(二)观察者
场景:一般为model层对,controller和view进行的通知方式,不关心谁去接收,只负责发布信息。
❗️优势:解耦合
敏捷原则:接口隔离原则,开放-封闭原则
(三)单例
场景:确保程序运行期某个类,只有一份实例,用于进行资源共享控制。
❗️优势:使用简单,延时求值,易于跨模块
敏捷原则:单一职责原则
(四)策略
场景:定义算法族,封装起来,使他们之间可以相互替换。
❗️优势:使算法的变化独立于使用算法的用户
敏捷原则:接口隔离原则;多用组合,少用继承;针对接口编程,而非实现。
(五)工厂
场景:工厂方式创建类的实例,多与proxy模式配合,创建可替换代理类。
“专门定义一个类来负责创建其他类的实例,被创建的实例通常具有共同的父类。”
通过简单工厂模式的重构,我们就是闲了低耦合度的代码结构,做到了对外扩展开放,对修改关闭。如果再增加任何的 操作方法,只需要继承操作方法父类,新建一个操作子类,并且在简单工厂类里面多添加一个else if的判断即可。
优点:简单工厂模式的优点是客户端可以直接消费产品,而不必关心具体产品的实现,消除了客户端直接创建产品对象的责任,实现了对责任的分割。
缺点:是工厂类几种了所有产品的创建逻辑,一旦不能正常工作,整个系统都会受到影响,而且当产品类多结构复杂的时候,把所有创建工作放进一个工厂中来,回事后期程序的扩展较为困难。
通过优缺点的分析,我们可以再如下场景中使用简单工厂模式:
(1)工厂类负责创建的对象较少时;
(2)客户端只知道传入工厂类的参数,对于如何创建对象的逻辑不必关心时。
敏捷原则:DIP依赖倒置原则
网友评论