装饰器模式(Decorator Pattern)
1.策略模式(Strategy Pattern)2.桥接模式(Bridge Pattern)3.代理模式(Proxy Pattern)4.中介者模式(Mediator Pattern)5.过滤器模式(Filter Pattern)6.适配器模式(Adapter Pattern)7.责任链模式(Chain Of Responsibility Pattern)
8.装饰器模式(Decorator Pattern)
9.建造者模式(Builder Pattern)10.观察者模式(Observer Pattern)11.工厂模式(Factory Pattern)12.单例模式(Singleton Pattern)13.组合模式(Composite Pattern)14.模板模式(Template Pattern)15.原型模式(Prototype Pattern)16.外观模式(Facade Pattern)17.享元模式(Flyweight Pattern)18.命令模式(Command Pattern)19.解释器模式(Interpreter Pattern)20.迭代器模式(Iterator Pattern)装饰器模式
一、什么是装饰器模式
装饰器模式(Decorator Pattern)允许向一个现有的对象添加新的功能,同时又不改变其结构。这种类型的设计模式属于结构型模式,它是作为现有的类的一个包装。
这种模式创建了一个装饰类,用来包装原有的类,并在保持类方法签名完整性的前提下,提供了额外的功能。
在不想增加更多子类的情况下扩展类,动态地给一个对象添加一些额外的职责。就增加功能来说,装饰器模式相比生成子类更为灵活。
二、装饰器模式的具体实现
1、结构图

2、分析
装饰器模式由组件和装饰者组成。
- 抽象组件(Component):需要装饰的抽象对象。
- 具体组件(ConcreteComponent):是我们需要装饰的对象。
- 抽象装饰类(Decorator):内含指向抽象组件的引用及装饰者共有的方法。
- 具体装饰类(ConcreteDecorator):被装饰的对象。
3、java 代码实现:
抽象组件:
package com.designpattern.decoratorPattern;
/**
* Component 组件 抽象角色
* @author zhongtao on 2018/10/23
*/
public interface House {
/**
* 装饰风格
*/
void style();
}
具体组件:
/**
* 具体组件
* @author zhongtao on 2018/10/23
*/
public class ChineseStyle implements House {
@Override
public void style() {
System.out.println("中式风格装修");
}
}
/**
* 具体组件
* @author zhongtao on 2018/10/23
*/
public class EuropeanStyle implements House {
@Override
public void style() {
System.out.println("欧式风格装修");
}
}
抽象装饰类:
package com.designpattern.decoratorPattern;
/**
* 抽象装饰类
*
* @author zhongtao on 2018/10/23
*/
public class HouseDecorator implements House {
public House house;
public HouseDecorator(House house) {
this.house = house;
}
@Override
public void style() {
house.style();
}
}
具体装饰类:
package com.designpattern.decoratorPattern;
/**
* 具体装饰类
*
* @author zhongtao on 2018/10/23
*/
public class RedDecorator extends HouseDecorator {
public RedDecorator(House house) {
super(house);
}
public void style() {
this.house.style();
System.out.println("红色装饰墙");
}
}
测试装饰器模式:
package com.designpattern.decoratorPattern;
import org.junit.Test;
/**
* 测试装饰器模型
*
* @author zhongtao on 2018/10/22
*/
public class DecoratorPatternTest {
/**
* 测试装饰器模型
*/
@Test
public void testDecoratorPattern(){
ChineseStyle chineseStyle = new ChineseStyle();
House redChineseStyle = new RedDecorator(new ChineseStyle());
House redEuropeanStyle = new RedDecorator(new EuropeanStyle());
System.out.println("中式装修");
chineseStyle.style();
System.out.println("\n中式加红色墙");
redChineseStyle.style();
System.out.println("\n欧式加红色墙");
redEuropeanStyle.style();
}
}
测试结果:
---中式装修---
中式风格装修
---中式加红色墙---
中式风格装修
红色装饰墙
---欧式加红色墙---
欧式风格装修
红色装饰墙
三、装饰器的优缺点
1、优点
- 装饰类和被装饰类可以独立发展,不会相互耦合。
- 装饰器模式是继承的一个替代模式。
- 装饰器模式可以动态扩展一个实现类的功能。
2、缺点
- 多层装饰比较复杂。
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· 阿里巴巴 QwQ-32B真的超越了 DeepSeek R-1吗?
· 【译】Visual Studio 中新的强大生产力特性
· 【设计模式】告别冗长if-else语句:使用策略模式优化代码结构
· AI与.NET技术实操系列(六):基于图像分类模型对图像进行分类