23种设计模式之装饰者模式
文章目录
- 23种设计模式之装饰者模式
- 设计思想
- 装饰者模式的优点
- 装饰者模式的缺点
- 装饰者模式的优化方法
- UML 解析
- 预设场景
- 代码释义
- 总结
设计思想
原文:装饰器模式(Decorator Pattern)允许向一个现有的对象添加新的功能,同时又不改变其结构。这种类型的设计模式属于结构型模式,它是作为现有的类的一个包装。
这种模式创建了一个装饰类,用来包装原有的类,并在保持类方法签名完整性的前提下,提供了额外的功能。把一个形状装饰上不同的颜色,同时又不改变形状类。
简述:看到原文介绍,很多人会认为装饰者模式与代理模式没区别,其实区别还是有的,只是在用的时候可能会存在异变代理模式,装饰者模式其根本是为了 增强被装饰者的方法。
装饰者模式的优点
- 可以在不修改原有对象的基础上给对象增加新的功能,遵循开闭原则。
- 可以使用多个具体装饰者来组合出不同的功能,实现灵活性和可扩展性。
- 可以根据需要动态地增加或删除功能,而不影响其他对象。
- 可以保持被装饰对象的类型和接口不变,对客户端透明。
装饰者模式的缺点
-会增加系统的复杂度和类的数量,可能导致代码难以理解和维护。
- 会增加对象之间的耦合度,可能引入循环引用的问题。
- 会影响被装饰对象的效率和性能。
- 动态地多层装饰时,调试和维护比较困难
装饰者模式的优化方法
- 尽量减少装饰者的数量和层次,避免过度使用装饰者模式
- 使用工厂方法或者建造者模式来创建装饰者对象,简化客户端的调用
- 使用组合/聚合代替继承,降低装饰者和被装饰者之间的耦合度
UML 解析
预设场景
RanchStaff 牧场工作人员
CowRanch 奶牛牧场
MilkProcessing 牛奶加工
RanchAiRobot 牧场人工智能机器人
牧场工作人员可以挤奶 生产牛奶 但是我想在生产牛奶前进行消毒处理以及牛奶生产后进行包装
代码释义
/**
* 奶牛牧场
*/
public interface CowRanch {
void milkProduction();
}
public class MilkProcessing extends RanchAiRobot {
public MilkProcessing(CowRanch cowRanch) {
super(cowRanch);
}
public void disinfect() {
System.out.println("先进行消毒 处理");
}
@Override
public void milkProduction() {
disinfect();
super.milkProduction();
packageMilk();
}
public void packageMilk() {
System.out.println("将生产出的牛奶进行包装");
}
}
/**
* 牧场人工智能 机器人
*/
public abstract class RanchAiRobot implements CowRanch {
private CowRanch cowRanch;
public RanchAiRobot() {
}
public RanchAiRobot(CowRanch cowRanch) {
this.cowRanch = cowRanch;
}
public void milkProduction() {
cowRanch.milkProduction();
}
}
/**
* 牧场工作人员
*/
public class RanchStaff implements CowRanch {
public void milkProduction() {
System.out.println("将奶牛的奶挤出,制成牛奶");
}
}
总结
装饰者模式 其核心就是为了增强方法,对原业务的扩展,以上面的场景来说,牧场工作人员只做牛奶的生产,但是想要对牛奶进行销售,只生产是不够的,生产前后都需要增加其他的行为。
装饰抽象层存在的意义 抽象类实现接口,可以选择性的去实现接口的抽象方法,并不需要重写接口所有方法,装饰抽象层可以精确的让具体装饰者去装饰某一个行为。