设计模式-装饰者模式应用实践

装饰者模式(Decorator Pattern)是一种结构型设计模式,它允许动态地向一个现有的对象添加新的功能,同时不改变其结构。这种模式通过创建一个装饰类来包装原有的类,提供额外的行为。

下面是一个使用 Java 实现装饰者模式的实践案例:

场景描述

假设我们正在开发一个咖啡馆应用程序,需要能够计算订单中各种类型咖啡的成本。基本咖啡可以添加多种调料(如摩卡、奶泡、豆浆等),每种调料都会增加咖啡的成本。

步骤1:定义组件接口

复制代码
1// 咖啡接口,作为所有咖啡和调料的基类
2public interface Coffee {
3    String getDescription();
4    double getCost();
5}

步骤2:实现具体组件

复制代码
1// 简单咖啡类,实现咖啡接口
2public class SimpleCoffee implements Coffee {
3    @Override
4    public String getDescription() {
5        return "Simple Coffee";
6    }
7
8    @Override
9    public double getCost() {
10        return 10; // 基础价格
11    }
12}

步骤3:创建装饰者抽象类

复制代码
1// 咖啡装饰者抽象类,实现咖啡接口并持有一个咖啡接口的引用
2public abstract class CoffeeDecorator implements Coffee {
3    protected Coffee decoratedCoffee;
4
5    public CoffeeDecorator(Coffee coffee) {
6        this.decoratedCoffee = coffee;
7    }
8
9    @Override
10    public String getDescription() {
11        return decoratedCoffee.getDescription();
12    }
13
14    @Override
15    public double getCost() {
16        return decoratedCoffee.getCost();
17    }
18}

步骤4:实现具体装饰者

复制代码
1// 摩卡装饰者,添加摩卡调料的功能
2public class MochaDecorator extends CoffeeDecorator {
3    public MochaDecorator(Coffee coffee) {
4        super(coffee);
5    }
6
7    @Override
8    public String getDescription() {
9        return decoratedCoffee.getDescription() + ", Mocha";
10    }
11
12    @Override
13    public double getCost() {
14        return decoratedCoffee.getCost() + 2; // 添加摩卡调料的成本
15    }
16}
17
18// 奶泡装饰者,添加奶泡调料的功能
19public class WhipDecorator extends CoffeeDecorator {
20    public WhipDecorator(Coffee coffee) {
21        super(coffee);
22    }
23
24    @Override
25    public String getDescription() {
26        return decoratedCoffee.getDescription() + ", Whip";
27    }
28
29    @Override
30    public double getCost() {
31        return decoratedCoffee.getCost() + 1; // 添加奶泡调料的成本
32    }
33}
34
35// 其他装饰者类似...

步骤5:客户端代码使用装饰者

复制代码
1public class DecoratorPatternDemo {
2    public static void main(String[] args) {
3        Coffee coffee = new SimpleCoffee();
4        System.out.println(coffee.getDescription() + " Cost: $" + coffee.getCost());
5
6        coffee = new MochaDecorator(coffee);
7        System.out.println(coffee.getDescription() + " Cost: $" + coffee.getCost());
8
9        coffee = new WhipDecorator(coffee);
10        System.out.println(coffee.getDescription() + " Cost: $" + coffee.getCost());
11
12        // 可以继续添加更多装饰者
13        // coffee = new SoyDecorator(coffee);
14        // System.out.println(coffee.getDescription() + " Cost: $" + coffee.getCost());
15    }
16}

在此实践案例中,CoffeeDecorator 类提供了一个包装咖啡对象的功能。具体的装饰者类(如 MochaDecorator 和 WhipDecorator)添加了额外的行为和成本。通过这种方式,我们可以组合不同的装饰者来创建多种咖啡变体,而无需为每一种组合创建一个新类。

装饰者模式是一种灵活的替代方案,相比生成子类更为优雅。这种模式非常适合用于扩展类的功能,特别是当我们希望在运行时能够动态地添加或删除功能时。此模式也遵循开闭原则,因为我们可以添加新的装饰者类而不修改现有代码。

相关推荐
程序员JerrySUN12 分钟前
Linux 内核内存管理子系统全面解析与体系构建
java·linux·运维
q5673152314 分钟前
分布式增量爬虫实现方案
开发语言·分布式·爬虫·python
勤奋的知更鸟20 分钟前
LLaMA-Factory和python版本的兼容性问题解决
开发语言·python·llama-factory
CIb0la22 分钟前
Ai自动补全编程工具:llama vscode
运维·开发语言·学习·测试工具·程序人生
风象南26 分钟前
SpringBoot的5种签到打卡实现方案
java·spring boot·后端
1candobetter32 分钟前
JAVA后端开发——多租户
java·开发语言
freyazzr1 小时前
C++八股 | Day3 | 智能指针 / 内存管理 / 内存分区 / 内存对齐
开发语言·c++
序属秋秋秋1 小时前
《C++初阶之入门基础》【普通引用 + 常量引用 + 内联函数 + nullptr】
开发语言·c++·笔记
星辰离彬1 小时前
Java 高级泛型实战:8 个场景化编程技巧
java·开发语言·后端·程序人生
筏.k1 小时前
C++ 网络编程(10) asio处理粘包的简易方式
java·网络·c++