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

装饰模式(Decorator Pattern)

非常好!现在我们来深入讲解装饰模式(Decorator Pattern),这是一个非常实用、优雅的结构型设计模式,在 Python 中用得特别广泛(比如 @装饰器语法)。


🧠 一句话定义

装饰模式允许你在不修改对象结构的前提下,动态地增强对象功能


🎯 为什么需要装饰模式?

传统做法是通过继承来扩展功能:

class A:def feature()...class B(A):def feature()...

但继承的问题是:

  • 🔴 不灵活(只能提前写死)
  • 🔴 类爆炸(每种组合都要继承一个新类)

✅ 装饰模式用组合(has-a)+ 包装替代继承,让你可以随时“包一层功能”


✅ 优点 vs ❌ 缺点

✅ 优点❌ 缺点
动态组合功能(灵活)多层嵌套调试困难
避免子类爆炸对初学者理解稍难
满足开闭原则(可扩展功能)包装类过多时结构复杂

🐍 Python 示例:咖啡点单系统(功能叠加)


☕ Step 1️⃣:定义饮品的接口(Component 抽象类)

from abc import ABC, abstractmethodclass Drink(ABC):@abstractmethoddef cost(self):pass@abstractmethoddef description(self):pass

☕ Step 2️⃣:基础饮品类(Concrete Component)

class Coffee(Drink):def cost(self):return 10  # 基础咖啡价格def description(self):return "原味咖啡"

🧁 Step 3️⃣:装饰器基类(Decorator)

class DrinkDecorator(Drink):def __init__(self, drink: Drink):self._drink = drink  # 组合基础饮品def cost(self):return self._drink.cost()def description(self):return self._drink.description()

🍬 Step 4️⃣:具体装饰器(增加功能)

class Milk(DrinkDecorator):def cost(self):return self._drink.cost() + 2  # 加牛奶加 2 元def description(self):return self._drink.description() + " + 牛奶"class Sugar(DrinkDecorator):def cost(self):return self._drink.cost() + 1  # 加糖加 1 元def description(self):return self._drink.description() + " + 糖"

🧪 Step 5️⃣:客户端使用示例(叠加装饰)

drink->drink->drink->叠加

# 创建一个基础咖啡
drink = Coffee()# 加牛奶
drink = Milk(drink)# 再加糖
drink = Sugar(drink)# 输出总价和描述
print(f"你点的是: {drink.description()}")
print(f"总价是: {drink.cost()} 元")

✅ 输出结果:

你点的是: 原味咖啡 + 牛奶 + 糖
总价是: 13 元

🧭 类图结构图(Mermaid)

«interface»
Drink
+cost()
+description()
Coffee
+cost()
+description()
DrinkDecorator
-Drink _drink
+cost()
+description()
Milk
Sugar

🔁 调用流程图(Mermaid)

Client Coffee Milk Sugar cost() = 10 包装 Coffee cost() = 10 ➕ 2 包装 Milk cost() = 12 ➕ 1 Client Coffee Milk Sugar

🧠 总结口诀

✅ 装饰模式:不动源对象,包一层加功能


🧩 应用场景

应用场景示例
UI 控件增强给按钮添加边框、阴影
数据处理链日志记录 → 缓存 → 加密等操作链
订单计价系统饮品 / 披萨 / 套餐的组合扩展

是否想继续深入下去,比如:

  • 使用 Python 内置 @decorator 实现?
  • 用函数式写法模拟装饰器类?
  • 将代码封装成插件系统结构?

我可以帮你再进一步优化或转换实战方向!是否继续?

http://www.xdnf.cn/news/279883.html

相关文章:

  • 【C++】运算符重载
  • 图片压缩与尺寸调整的便捷工具推荐
  • 主成分分析(PCA)与逻辑回归在鸢尾花数据集上的实践与效果对比
  • 【翻译、转载】MCP 工具 (Tools)
  • 【python实用小脚本-47】用Python打造高效的信息推送系统:从问题到解决方案的实战之旅
  • 【默子AI】Anthropic Claude LLM对齐伪装 解读
  • Temp Mail 1.7.0 | 创建和管理临时邮箱,防止垃圾邮件骚扰,保护隐私安全
  • 高效便捷的定时关机与任务管理工具
  • Java学习手册:MyBatis 框架作用详解
  • 【循环依赖(Circular Dependency)】
  • 2025信息安全网络安全意识培训资料汇编(24份)
  • Day 4:牛客周赛Round 91
  • 力扣刷题(第十六天)
  • Mamba+Attention+CNN 预测模型:破局长程依赖的计算机视觉新范式
  • 24:条码解析
  • 深度剖析:丝杆升降机与齿条的传动特性、应用场景及选型策略
  • go语言实现用户管理系统
  • [计算机网络]拓扑结构
  • Allegro23.1新功能之如何去除钻孔表中一钻钻头孔径和公差操作指导
  • Qt输入控件(QInput Widgets)详解:从基础到实战
  • 前端面经-VUE3篇(三)--vue Router(二)导航守卫、路由元信息、路由懒加载、动态路由
  • idea创建springboot项目无法创建jdk8原因及多种解决方案
  • 递归下降算法
  • 结构型模式:外观模式
  • Python 数据智能实战 (12):效果评估 - 超越传统指标
  • 平台介绍-开放API接口-IO说明
  • 阿里云服务器全栈技术指导手册(2025版)
  • 基于 PyQt 的YOLO目标检测可视化界面+ nuitka 打包
  • Spring AI 实战:第六章、Spring AI源码浅析之一山可容二虎
  • 实验四 增强型可靠文件传输系统