装饰器模式及应用【理论+代码】

装饰器模式(Decorator

Pattern)是一种结构型设计模式,它允许向一个现有的对象添加新的功能,同时又不改变其结构。这种设计模式通过创建一个包装对象,即装饰器,来封装实际对象。

装饰器模式的主要组成:

组件接口:定义了对象的接口,可以给这些对象动态地添加职责。

具体组件:定义了将要接收附加责任的对象。

装饰器:持有一个组件对象的引用,并定义一个与组件接口一致的接口。

具体装饰器:负责给组件添加新的责任。

应用场景:

需要扩展一个类的功能。

动态地添加功能。

需要通过子类化来扩展功能,但又想避免使用继承带来的缺点。

  1. 定义一个coffer组件接口
java 复制代码
public interface Coffee {
    double getCost();
    String getDescription();
}

2.实现一个便宜的黑咖啡,一块钱一杯

java 复制代码
public class SimpleCoffee implements Coffee {
    @Override
    public double getCost() {
        return 1;
    }

    @Override
    public String getDescription() {
        return "Simple coffee";
    }
}

如何把这杯黑咖啡升值呢???当然我需要给它包装,这个时候装饰器设计模式来了,让便宜点黑咖啡山鸡变凤凰!!!

  1. 装饰器抽象类来了,它可以将任何咖啡包装成你高攀不起的样子!!!
java 复制代码
public abstract class CoffeeDecorator implements Coffee {
    protected final Coffee decoratedCoffee;

	//这和代理模式的区别,这里的类是通过构造器传过来的
    public CoffeeDecorator(Coffee coffee) {
        this.decoratedCoffee = coffee;
    }

    @Override
    public double getCost() {
        return decoratedCoffee.getCost();
    }

    @Override
    public String getDescription() {
        return decoratedCoffee.getDescription();
    }
}
  1. 不信?那我来实现个卡布奇诺
java 复制代码
public class Cappuccino Decorator extends CoffeeDecorator {
    public Cappuccino (Coffee coffee) {
        super(coffee);
    }

    @Override
    public double getCost() {
        return super.getCost() + 31;
    }

    @Override
    public String getDescription() {
        return super.getDescription() + ", with milk";
    }
}
  1. 出来吧!包装版卡布奇诺
java 复制代码
public class CoffeeShop {
    public static void main(String[] args) {
        Coffee coffee = new SimpleCoffee();
        System.out.println(coffee.getCost()); // 1
        System.out.println(coffee.getDescription()); // Simple coffee

        Coffee cappuccino = new Cappuccino (coffee);
        System.out.println(cappuccino .getCost()); // 32
        System.out.println(cappuccino .getDescription()); // Simple coffee, with milk
     }
}

那么,这样做有啥好处呢?我用类继承也可以实现啊

装饰器模式提供了一种灵活的替代继承的方法来扩展对象的行为。通过添加新的装饰器类,可以轻松地为现有对象添加新功能,而不需要修改原有代码。

灵活性:可以在运行时动态地添加或移除装饰器,从而改变对象的行为。这使得程序更加灵活,能够适应不断变化的需求。

低耦合性:装饰器模式通过组合而非继承来扩展功能,减少了类之间的依赖关系。这有助于降低系统的耦合度,使得代码更容易维护和扩展。

责任分离:装饰器模式将系统的不同功能分离开来,每个装饰器类负责特定的功能扩展。这种责任分离有助于降低系统的复杂性,使得各个部分更容易理解和管理。

支持开闭原则:装饰器模式支持开闭原则,即对扩展开放,对修改关闭。可以通过添加新的装饰器来扩展系统功能,而不需要修改现有代码。

相关推荐
Cherry的跨界思维1 小时前
28、AI测试环境搭建与全栈工具实战:从本地到云平台的完整指南
java·人工智能·vue3·ai测试·ai全栈·测试全栈·ai测试全栈
MM_MS1 小时前
Halcon变量控制类型、数据类型转换、字符串格式化、元组操作
开发语言·人工智能·深度学习·算法·目标检测·计算机视觉·视觉检测
꧁Q༒ོγ꧂1 小时前
LaTeX 语法入门指南
开发语言·latex
njsgcs2 小时前
ue python二次开发启动教程+ 导入fbx到指定文件夹
开发语言·python·unreal engine·ue
alonewolf_992 小时前
JDK17新特性全面解析:从语法革新到模块化革命
java·开发语言·jvm·jdk
一嘴一个橘子2 小时前
spring-aop 的 基础使用(啥是增强类、切点、切面)- 2
java
sheji34162 小时前
【开题答辩全过程】以 中医药文化科普系统为例,包含答辩的问题和答案
java
古城小栈2 小时前
Rust 迭代器产出的引用层数——分水岭
开发语言·rust
ghie90902 小时前
基于MATLAB的TLBO算法优化实现与改进
开发语言·算法·matlab
恋爱绝缘体12 小时前
2020重学C++重构你的C++知识体系
java·开发语言·c++·算法·junit