博客
关于我
设计模式-装饰者模式
阅读量:805 次
发布时间:2019-03-23

本文共 1604 字,大约阅读时间需要 5 分钟。

装饰者模式是面向对象编程中常用的一种高级设计模式。它允许我们对一对象的行为和属性进行动态的扩展,而无需修改现有的类结构。这与传统的继承方式相比,具有更高的灵活性和可扩展性。在本文中,我们将逐步阐述装饰者模式的设计思想、实现原理及其在实际项目中的应用实例。

装饰者模式分析

星巴克咖啡订单项目中,我们需要处理多种咖啡单品及其调料组合。选择传统的继承方式会导致大量waitlist类的生成,当需要新增单品咖啡或调料时,类的数量会呈指数级增长,导致维护成本高昂。为了解决这一问题,装饰者模式提供了一种更加灵活的解决方案。

装饰者模式在咖啡订单中的应用

  • 基类设计

    • Drink abstract类,代表所有咖啡饮品。
    • 每个咖啡单品都继承自Drink类,如ShortBlackEspresso等。
    • Coffee concrete类继承自Drink类,用于具体实现咖啡的价格和描述。
  • 装饰者类设计

    • Decorator类,作为基装饰者,持有一个Drink对象。
    • 具体的装饰者如MilkSoy等继承自Decorator类,它会在CoffeeDrink的基础上增加调料的描述和价格。
  • 动态组合

    • 使用装饰者可以实现任意的组合方式,例如:一份LongBlack加上一份Milk和两份Chocolate,可以通过多次调用Decorator构造相应的饮品。
  • 装饰者模式的核心原理

    装饰者模式的核心思想是动态地对一个对象的行为进行扩展。与传统的继承方式相比,其优点:

  • 避免类爆炸:通过动态组合而非硬编码,减少新增类的需求。
  • 提高维护性:当需要修改或新建调料时,只需添加新的装饰者类,不会影响现有类结构。
  • 灵活性高:可以根据实际需求自由组合不同的装饰者,满足多样化的订单需求。
  • 实例解析

    以咖啡订单项目为例:

    // 点一份长黑咖啡Drink order = new LongBlack();// 加入牛奶order = new Milk(order);// 加入一道巧克力order = new Chocolate(order);// 再加一道巧克力,可以叠加多个装饰者order = new Chocolate(order);// 最终价格:LongBlack的价格 + 牛奶的价格 + 两次巧克力的价格System.out.println("总费用:" + order.cost());

    每个Decorator类通过持有原始饮品对象和在cost()getDes()等方法中递归调用原始对象的方法,动态构建最终的饮品描述和价格。

    JDK中的装饰者模式

    在Java标准库中,装饰者模式广泛用于文件读取和数据加工流程。例如,FilterInputStream类就是一个典型的装饰者类,它包裹了原始的InputStream对象,并对其输入流程进行扩展。例如:

    public abstract class InputStream implements Closeable {    // 基本输入流操作方法    ...}public class FilterInputStream extends InputStream {    protected volatile InputStream in;    public FilterInputStream(InputStream input) {        this.in = input;    }    // 具体实现输入流操作,如读取数据时进行过滤    public int read(byte[] b, int off, int len) {        return in.read(b, off, len);    }    ...}

    这个设计模式的优点显而易见:无论是向现有的类添加新功能,还是修改现有行为,仅需创建新的装饰者类即可,而无需修改原始类结构。

    转载地址:http://tctzk.baihongyu.com/

    你可能感兴趣的文章
    NIFI从MySql中增量同步数据_通过Mysql的binlog功能_实时同步mysql数据_配置数据路由_生成插入Sql语句_实际操作02---大数据之Nifi工作笔记0041
    查看>>
    NIFI从MySql中离线读取数据再导入到MySql中_03_来吧用NIFI实现_数据分页获取功能---大数据之Nifi工作笔记0038
    查看>>
    NIFI从MySql中离线读取数据再导入到MySql中_不带分页处理_01_QueryDatabaseTable获取数据_原0036---大数据之Nifi工作笔记0064
    查看>>
    NIFI从MySql中离线读取数据再导入到MySql中_无分页功能_02_转换数据_分割数据_提取JSON数据_替换拼接SQL_添加分页---大数据之Nifi工作笔记0037
    查看>>
    NIFI从PostGresql中离线读取数据再导入到MySql中_带有数据分页获取功能_不带分页不能用_NIFI资料太少了---大数据之Nifi工作笔记0039
    查看>>
    nifi使用过程-常见问题-以及入门总结---大数据之Nifi工作笔记0012
    查看>>
    NIFI分页获取Mysql数据_导入到Hbase中_并可通过phoenix客户端查询_含金量很高的一篇_搞了好久_实际操作05---大数据之Nifi工作笔记0045
    查看>>
    NIFI分页获取Postgresql数据到Hbase中_实际操作---大数据之Nifi工作笔记0049
    查看>>
    NIFI同步MySql数据_到SqlServer_错误_驱动程序无法通过使用安全套接字层(SSL)加密与SQL Server_Navicat连接SqlServer---大数据之Nifi工作笔记0047
    查看>>
    Nifi同步过程中报错create_time字段找不到_实际目标表和源表中没有这个字段---大数据之Nifi工作笔记0066
    查看>>
    NIFI大数据进阶_FlowFile拓扑_对FlowFile内容和属性的修改删除添加_介绍和描述_以及实际操作---大数据之Nifi工作笔记0023
    查看>>
    NIFI大数据进阶_FlowFile生成器_GenerateFlowFile处理器_ReplaceText处理器_处理器介绍_处理过程说明---大数据之Nifi工作笔记0019
    查看>>
    NIFI大数据进阶_Json内容转换为Hive支持的文本格式_操作方法说明_01_EvaluteJsonPath处理器---大数据之Nifi工作笔记0031
    查看>>
    NIFI大数据进阶_Kafka使用相关说明_实际操作Kafka消费者处理器_来消费kafka数据---大数据之Nifi工作笔记0037
    查看>>
    NIFI大数据进阶_Kafka使用相关说明_实际操作Kafka生产者---大数据之Nifi工作笔记0036
    查看>>
    NIFI大数据进阶_NIFI的模板和组的使用-介绍和实际操作_创建组_嵌套组_模板创建下载_导入---大数据之Nifi工作笔记0022
    查看>>
    NIFI大数据进阶_NIFI监控功能实际操作_Summary查看系统和处理器运行情况_viewDataProvenance查看_---大数据之Nifi工作笔记0026
    查看>>
    NIFI大数据进阶_NIFI监控的强大功能介绍_处理器面板_进程组面板_summary监控_data_provenance事件源---大数据之Nifi工作笔记0025
    查看>>
    NIFI大数据进阶_NIFI集群知识点_认识NIFI集群以及集群的组成部分---大数据之Nifi工作笔记0014
    查看>>
    NIFI大数据进阶_NIFI集群知识点_集群的断开_重连_退役_卸载_总结---大数据之Nifi工作笔记0018
    查看>>