【Python设计模式05】装饰模式

装饰模式(Decorator Pattern)是一种结构型设计模式,它允许向一个现有对象添加新的功能,同时又不改变其结构。装饰模式通过创建一个装饰类来包裹原始类,从而在不修改原始类代码的情况下扩展对象的功能。

装饰模式的结构

装饰模式包含以下几个角色:

  1. 组件接口(Component):定义对象的接口,可以动态地给对象添加职责。
  2. 具体组件(ConcreteComponent):实现组件接口的类,代表要被装饰的对象。
  3. 装饰器(Decorator):实现组件接口,并持有一个组件对象(通常是通过组合的方式)。
  4. 具体装饰器(ConcreteDecorator):扩展装饰器类,添加新的职责。

示例

假设我们有一个基本的文本消息类,我们希望能够动态地添加一些装饰功能,比如加密消息或将消息转换为大写。

定义组件接口和具体组件
from abc import ABC, abstractmethodclass Message(ABC):@abstractmethoddef get_content(self) -> str:passclass TextMessage(Message):def __init__(self, content: str):self.content = contentdef get_content(self) -> str:return self.content
定义装饰器和具体装饰器
class MessageDecorator(Message):def __init__(self, message: Message):self._message = messagedef get_content(self) -> str:return self._message.get_content()class EncryptedMessage(MessageDecorator):def get_content(self) -> str:original_content = super().get_content()return self._encrypt(original_content)def _encrypt(self, content: str) -> str:return f"Encrypted({content})"class UppercaseMessage(MessageDecorator):def get_content(self) -> str:original_content = super().get_content()return original_content.upper()
使用装饰器
def main():message = TextMessage("Hello, World!")encrypted_message = EncryptedMessage(message)print(encrypted_message.get_content())  # 输出:Encrypted(Hello, World!)uppercase_message = UppercaseMessage(message)print(uppercase_message.get_content())  # 输出:HELLO, WORLD!# 组合装饰器encrypted_uppercase_message = EncryptedMessage(UppercaseMessage(message))print(encrypted_uppercase_message.get_content())  # 输出:Encrypted(HELLO, WORLD!)if __name__ == "__main__":main()

在这个示例中,Message是组件接口,TextMessage是具体组件,MessageDecorator是装饰器,EncryptedMessageUppercaseMessage是具体装饰器。装饰器可以在不修改TextMessage类的情况下,动态地给对象添加新的功能。

装饰模式的优缺点

优点
  1. 遵循开闭原则:可以在不修改现有代码的情况下扩展对象的功能。
  2. 组合功能:可以通过多个装饰器组合来实现复杂的功能。
  3. 灵活性:可以动态地添加或移除对象的功能。
缺点
  1. 增加复杂性:每个装饰器都需要创建一个新类,可能会导致类的数量增加,增加系统的复杂性。
  2. 调试困难:由于装饰器的层次结构,调试可能会变得更加复杂。

装饰模式的适用场景

  1. 需要动态地添加功能:当需要动态地给对象添加功能,并且可以在运行时选择不同的装饰器时,适合使用装饰模式。
  2. 替代子类继承:当通过子类继承来扩展功能导致类爆炸时,可以考虑使用装饰模式。

总结

装饰模式是一种结构型设计模式,通过创建装饰类来包裹原始类,实现动态地给对象添加新功能。装饰模式遵循开闭原则,使得系统更具灵活性和可扩展性。尽管装饰模式会增加系统的复杂性,但在需要动态扩展对象功能的场景中,装饰模式是一种非常有用的设计模式。合理应用装饰模式,可以显著提高代码的可维护性和可复用性。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/pingmian/13801.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Python踩坑系列之使用redis报错:module ‘redis‘ has no attribute ‘Redis‘问题

一步一步往后看哦!!! 纳尼,大伙看看这是什么情况,都是这么写的呢,为啥我这就报错了0.0 出现问题不可怕,解决它就完事了。 方法一、安装redis重新运行程序 pip install redis 无果&#xff0…

金丝雀发布(灰度发布)介绍 及 声明式管理方法简介

目录 一 应用发布策略 1,滚动发布(k8s默认) 2,蓝绿发布 3,金丝雀发布 二 金丝雀发布(Canary Release) (灰度发布) 1,金丝雀发布图解 2&#xff0…

Oracle事务开始时的SCN

Oracle为每一个事物都分配一个唯一的SCN值,事务开始时的SCN可以从V$TRANSACTION.START_SCNB START_SCNW中查询,如下所示: SQL> update t2 set obj#1 where rownum1; 1 row updated. SQL> select XIDUSN,START_SCNB,START_SCNW from v…

数据库操作(函数)

函数是一段可以直接被另外一段程序调用的程序或代码 一。字符串函数 1.concat(s1,s1....sn):字符串拼接,将s1,s2,sn拼接为一个字符串 例如: select concat("hello","world"); 2.lower(str&…

登录验证登录次数失败过多进行设置延时

现象结果示例截图 swagger示例效果 控制台示例效果 后端代码示例 package com.java.javamethod.service.impl;import com.java.javamethod.dao.UserMapper; import com.java.javamethod.domain.Result; import com.java.javamethod.domain.User; import lombok.extern.slf4j.…

《绝地潜兵2》开发商目标成为下一个暴雪或FS社

《绝地潜兵2》的开发商Arrowhead正以惊人的表现在游戏界崭露头角。这款游戏在发售后迅速获得了巨大成功,使得Arrowhead的首席创意官Johan Pilestedt怀揣雄心壮志,他们的目标是在保持独立的同时,成为下一个暴雪或From Software。 Johan Pilest…

firewalld

一、Firewalld概述 Firewalld 支持网络区域所定义的网络链接以及接口安全等级的动态防火墙管理工具 支持IPV4、IPV6防火墙设置以及以太网桥 支持服务或应用程序直接添加防火墙规则接口 拥有两种配置模式 运行时配置 永久配置 二、Firewalld和iptables的关系 netfilter 位于L…

java中的抽象类到底如何用

抽象类的使用 一、设计模式中的使用1. 模板方法模式2. 抽象工厂模式 二、扩展性和灵活性三、为什么开发时抽象类用的很少,反而用接口的很多 一、设计模式中的使用 1. 模板方法模式 1.定义:当你需要为一组相关类提供一个操作的框架,其中一些…

【Muduo】三大核心之EventLoop

Muduo网络库的EventLoop模块是网络编程框架中的核心组件,负责事件循环的驱动和管理。以下是对EventLoop模块的详细介绍: 作用与功能: EventLoop是网络服务器中负责循环的重要模块,它持续地监听、获取和处理各种事件,…

10个最佳Android数据恢复工具,用于恢复已删除的文件

由于我们现在在智能手机上存储了许多重要文件,因此了解数据恢复工具变得很重要。您永远不会知道何时需要使用适用于Android的数据恢复工具。 由于不乏Windows数据恢复工具,因此从崩溃的计算机中恢复文件很容易。但是,当涉及到从Android恢复数…

兆原数通基于Apache SeaTunnel的探索实践

随着大数据技术的不断发展,数据同步工具在企业中的应用变得愈发重要。为了满足复杂多样的业务需求,找到一款高效、灵活的数据同步工具变得尤为关键。 在这篇文章中,我们将分享兆原数通研发经理李洪军对Apache SeaTunnel的选择、应用及经验。这…

jinkens打包前端依赖下载失败怎么办

不知道有没有小伙伴遇见这种问题,项目在本地可以正常下载、运行打包,但在jinkens上就不行了,配置了几种镜像也还是不行,这要如何解决呢? 那就只能去到jinkens配置的工作空间那里,找到对应的项目 &#xff…

Django使用Celery实现异步和定时任务功能

1、装库 celery==4.4.2 django-celery-beat==2.2.0 django-celery-results==2.0.12、添加应用 安装完依赖之后,把上面的两个应用添加到Django配置文件settings.py的INSTALLED_APPS里面: 添加celery配置信息 在项目的配置文件中添加如下配置信息,具体的配置作用见注释 I…

YOLOv5/v7 应用轻量级通用上采样算子CARAFE

1. 介绍 CARAFE(Content-Aware ReAssembly of FEatures)是一种轻量级的通用上采样算子,它可以用于提高卷积神经网络(CNN)中特征图的分辨率。CARAFE 的特点是计算量小、参数少、易于实现,因此非常适合用于移…

开放重定向漏洞

开放重定向漏洞 1.开放重定向漏洞概述2.攻击场景:开放重定向上传 svg 文件3.常见的注入参数 1.开放重定向漏洞概述 开放重定向漏洞(Open Redirect)是指Web应用程序接受用户提供的输入(通常是URL参数),并将…

代码随想录算法训练营第四十五天|139.单词拆分

139.单词拆分 这题首先肯定是排序问题而不是组合问题,因为单词的顺序是一定的,所以组成单词的字符串顺序也是一定的。所以应该先循环背包容量,再循环物品个数。 背包容量就是s字符串,物品就是数组中的单词,字符串的循…

Kubernetes 文档 / 概念 / 工作负载 / Pod / Init 容器

Kubernetes 文档 / 概念 / 工作负载 / Pod / Init 容器 此文档从 Kubernetes 官网摘录 中文地址 英文地址 本页提供了 Init 容器的概览。Init 容器是一种特殊容器,在 Pod 内的应用容器启动之前运行。Init 容器可以包括一些应用镜像中不存在的实用工具和安装脚本。…

总结优秀的prompt案例,学习更有效的prompt提示词工程写法,值得收藏

Prompt 提示词工程大多数人都在用,而且都会用,但是不一定写的好?很多人都在想怎么写好,更能满足自己的业务需求,或者实际场景。 我最近工作中也写了很多的prompt,像zero-shot、few-shot、COT这些都尝试过、…

FSC认证是什么?森林认证的好处是什么?

FSC认证(Forest Stewardship Council,森林管理委员会认证)是一种运用市场机制来促进森林可持续经营,实现生态、社会和经济目标的工具。以下是关于FSC认证的详细介绍: 一、FSC认证包括两个方面: 森林经营认…

乡村振兴与农业现代化:以现代农业科技为引领,提升农业综合生产能力,打造高产高效、生态安全的美丽乡村

目录 一、引言 二、现代农业科技在乡村振兴中的作用 (一)提高农业生产效率 (二)促进农业产业升级 (三)改善农村生态环境 三、提升农业综合生产能力的途径 (一)加强农业科技研…