当前位置: 首页 > news >正文

【设计模式】-装饰器模式

Java 设计模式之装饰器模式

前言

在软件开发中,经常有需求对已有的对象进行功能的扩展,但是传统的继承方式会导致类的数量快速增多,且难以维护。为了解决这个问题,装饰器模式应运而生。

装饰器模式是一种结构型设计模式,它可以在运行时动态地将新的行为附加到对象上,而不改变其结构。这种方式极大地扩展了对象的功能,并且也遵循了开闭原则。

原理及实现思路

装饰器模式的核心思想是通过包装对象来增加新的行为并且可以递归地进行多层次的包装

1. 定义接口或抽象类

首先,我们需要定义一个接口或抽象类,它定义了核心功能的方法。这个接口或抽象类是被装饰的对象的类型,也是装饰器对象的类型。

public interface Component {void operation();
}

2. 实现核心功能

接着,我们实现核心功能的类。这个类提供了一些基本的操作。

public class ConcreteComponent implements Component {@Overridepublic void operation() {System.out.println("执行核心功能");}
}

3. 定义装饰器类

接下来,我们定义一个装饰器类,它实现了相同的接口或抽象类,并且持有一个核心功能对象的引用。

public abstract class Decorator implements Component {protected Component component;public Decorator(Component component) {this.component = component;}@Overridepublic void operation() {component.operation();}
}

4. 实现装饰器类

然后,我们可以定义具体的装饰器类,它继承自装饰器类并添加新的功能。

public class ConcreteDecorator extends Decorator {public ConcreteDecorator(Component component) {super(component);}@Overridepublic void operation() {super.operation();System.out.println("执行附加功能");}
}

5. 使用装饰器类

最后,我们可以使用装饰器类来扩展核心功能。

public class Main {public static void main(String[] args) {Component component = new ConcreteComponent();component.operation();Component decoratedComponent = new ConcreteDecorator(component);decoratedComponent.operation();}
}

运行上述代码可以得到如下输出:

执行核心功能
执行核心功能
执行附加功能

优缺点及适用场景

装饰器模式具有以下优点:

  • 动态地扩展对象的功能,不需要修改原有对象的结构。
  • 可以递归地进行多层次的装饰。
  • 遵循开闭原则,无需修改现有代码,只需新增装饰器类。

然而,装饰器模式也有一些缺点:

  • 会导致类的数量增多。
  • 装饰器类和被装饰的类可能存在相同的方法,增加了代码复杂性。
  • 在使用过程中需要注意装饰器的调用顺序。
http://www.lryc.cn/news/115066.html

相关文章:

  • 七月学习总结
  • Camunda 7.x 系列【6】Spring Boot 集成 Camunda 7.19
  • Kubernetes —调度器配置
  • 【微信小程序】申请蓝牙、位置和数据库等相关权限
  • ORB-SLAM2学习笔记6之D435i双目IR相机运行ROS版ORB-SLAM2并发布位姿pose的rostopic
  • 【数据结构与算法——TypeScript】哈希表
  • JavaScript 中常用简写语法技巧总结
  • 漫画算法做题笔记
  • JDBC学习笔记
  • 亚信科技AntDB数据库与库瀚存储方案完成兼容性互认证,联合方案带来约20%性能提升
  • 【MySQL】基础知识(一)
  • Ansible专栏目录
  • 【locust】使用locust + boomer实现对接口的压测
  • 亿欧智库:2023中国宠物行业新趋势洞察报告(附下载)
  • 时序数据库 TDengine 与 WhaleStudio 完成相互兼容性测试认证
  • Spring-1-深入理解Spring XML中的依赖注入(DI):简化Java应用程序开发
  • 负载均衡–HAProxy安装及搭建tidb数据库负载服务
  • Django各种缓存的配置
  • 实现跨域的几种方式
  • OpenCV: 对“google::protobuf::internal::Release_CompareAndSwap”的未定义
  • 无涯教程-Perl - References(引用)
  • 马斯克收购AI.com域名巩固xAI公司地位;如何评估大型语言模型的性能
  • uni-app:实现点击按钮出现底部弹窗(uni.showActionSheet+自定义)
  • flume系列之:监控zookeeper的flume配置写入节点,新增和删除flume agent节点,通过ansible自动部署和卸载flume agent
  • 了解以太网通信中的九阳神功 - SOME/IP协议
  • redis List类型命令
  • 【博客685】prometheus 出现NaN场景以及如何去除干扰(Not a Number)
  • 【计算机网络】网络层协议 -- ICMP协议
  • 机器学习---facebook的案例学习
  • OpenMMLab MMDetectionV3.1.0-SAM(环境安装、模型测试、训练以及模型后处理工具)