设计模式Python版 原型模式

ops/2025/2/1 22:45:18/

文章目录


前言

GOF设计模式分三大类:

  • 创建型模式:关注对象的创建过程,包括单例模式、简单工厂模式、工厂方法模式、抽象工厂模式、原型模式和建造者模式。
  • 结构型模式:关注类和对象之间的组合,包括适配器模式、桥接模式、组合模式、装饰模式、外观模式、享元模式和代理模式。
  • 行为型模式:关注对象之间的交互,包括职责链模式、命令模式、解释器模式、迭代器模式、中介者模式、备忘录模式、观察者模式、状态模式、策略模式、模板方法模式和访问者模式。

一、原型模式

原型模式(Prototype Pattern)

  • 定义:使用原型实例指定创建对象的种类,并且通过克隆这些原型创建新的对象。
  • 解决问题:如何通过克隆来得到一个一模一样的对象?(通过克隆方法所创建的对象是全新的对象,它们在内存中拥有新的地址。)
  • 使用场景:
    • 创建新对象成本较大
    • 系统要保存对象的状态
    • 在运行时动态地创建和定制对象
  • 组成:
    • 原型接口(Prototype):声明克隆自身的接口
    • 具体原型(ConcretePrototype):实现原型接口,提供克隆自身的操作。
    • 客户端(Client):让一个原型克隆自身,从而创建一个新的对象。
  • 优点:
    • 当创建新的对象实例较为复杂时,使用原型模式可以简化对象的创建过程,通过复制一个已有实例可以提高新实例的创建效率
    • 可以使用深克隆的方式保存对象的状态。使用原型模式将对象复制一份并将其状态保存起来,以便在需要的时候使用,例如恢复到某一历史状态,可辅助实现撤销操作
  • 缺点:
    • 注意深克隆与浅克隆的区别和使用场景

在这里插入图片描述

二、原型模式示例

使用原型模式快速创建工作周报

python">import copyclass Prototype:"""原型接口"""def clone(self):# 这里用深拷贝,这意味着对象及其所有引用的对象都将被复制# 若不希望复制对象内部的引用类型,copy.copy()来执行浅拷贝return copy.deepcopy(self)class WeeklyLog(Prototype):"""具体原型"""def __init__(self, name=None, date=None, content=None):self.name = nameself.date = dateself.content = content

客户端代码

python">def display_log(log: WeeklyLog):print("###周报###")print(f"姓名:{log.name}")print(f"周次:{log.date}")print(f"内容:{log.content}")print("#" * 10, "\n")log_lastweek = WeeklyLog("张三", "第12周", "这周工作很忙,每天加班!")
log_thisweek = log_lastweek.clone()
log_thisweek.date = "第13周"
display_log(log_lastweek)
display_log(log_thisweek)
print(log_lastweek is log_thisweek)  # 输出 False,表示是不同的对象

输出结果

###周报###
姓名:张三
周次:第12周
内容:这周工作很忙,每天加班!
#############周报###
姓名:张三
周次:第13周
内容:这周工作很忙,每天加班!
##########False

三、原型管理器

  • 原型管理器(Prototype Manager)是将多个原型对象存储在一个集合中供客户端使用,它是一个专门负责克隆对象的工厂
  • 原型管理器采用单例模式,能节省系统资源,也能更好地管理。定义一个集合存储原型对象,需要某个原型对象的一个克隆,调用相应对象的克隆方法来获得。
python">import copy"""原型接口"""class OfficialDocument:def clone(self):return copy.deepcopy(self)def display(self):raise NotImplementedError"""具体原型"""class FAR(OfficialDocument):def display(self):print("《可行性分析报告》")class SRS(OfficialDocument):def display(self):print("《软件需求规格说明书》")"""原型管理器(使用模块单例模式)"""class PrototypeManager:def __init__(self):self.official_docs: dict[str, OfficialDocument] = {}self.add_official_docs()def add_official_docs(self):self.official_docs["far"] = FAR()self.official_docs["srs"] = SRS()def get_official_doc(self, key: str) -> OfficialDocument:official_doc = self.official_docs.get(key, None)if official_doc:return official_doc.clone()prototype_manager = PrototypeManager()
  • 客户端代码
python">from prototypes import prototype_managerdoc1 = prototype_manager.get_official_doc("far")
doc2 = prototype_manager.get_official_doc("far")
doc1.display()
doc2.display()
print(doc1 is doc2)doc3 = prototype_manager.get_official_doc("srs")
doc4 = prototype_manager.get_official_doc("srs")
doc3.display()
doc4.display()
print(doc3 is doc4)
  • 输出结果
《可行性分析报告》
《可行性分析报告》    
False
《软件需求规格说明书》
《软件需求规格说明书》
False

您正在阅读的是《设计模式Python版》专栏!关注不迷路~


http://www.ppmy.cn/ops/154876.html

相关文章

5 长度和距离计算模块(length.rs)

这段代码定义了一个泛型结构体 Length<T, Unit>&#xff0c;用于表示一维长度&#xff0c;其中 T 表示长度的数值类型&#xff0c;而 Unit 是一个编译时检查单位一致性的占位符类型&#xff0c;不会用于运行时表示长度的值。这个设计允许开发者在编译阶段确保不同单位之间…

【C++高并发服务器WebServer】-8:终端、进程组、会话、守护进程

本文目录 一、终端二、进程组三、会话四、进程组、会话、控制终端之间的关系五、守护进程六、创建守护进程的流程 一、终端 在 UNIX 系统中&#xff0c;用户通过终端登录系统后得到一个shell 进程&#xff0c;这个终端成为 shell 进程的控制终端(Controlling Terminal)&#x…

舵机型号与识别

舵机型号繁多&#xff0c;不同品牌和制造商有不同的命名规则。常见的舵机品牌包括 Futaba、Hitec、Tower Pro、Savox、JX Servo 等。以下是舵机型号的常见识别方法以及一些典型的型号示例&#xff1a; 一、舵机型号的识别方法 型号命名规则&#xff1a; 舵机型号通常由字母和数…

vue3项目中编写less

css,less&#xff0c;sass文件一般写在vue3的asset目录下 1.引入依赖 npm install -D less2.定义less文件 3.在其他文件中引入less文件 如在app.vue文件中引入&#xff0c; 可使用绝对路径也可以使用相对路径

2025数学建模美赛|C题成品论文|第一问

1.模型建立与求解 1.1问题求解思路 为了准确预测奥运会奖牌分布情况&#xff0c;尤其是金牌数和奖牌总数&#xff0c;本研究采用以下步骤&#xff1a; &#xff08;1&#xff09;数据处理与特征工程 从提供的奥运会奖牌历史数据中提取核心信息。 补充外部特征&#xff0c;…

网络工程师 (8)存储管理

一、页式存储基本原理 &#xff08;一&#xff09;内存划分 页式存储首先将内存物理空间划分成大小相等的存储块&#xff0c;这些块通常被称为“页帧”或“物理页”。每个页帧的大小是固定的&#xff0c;例如常见的页帧大小有4KB、8KB等&#xff0c;这个大小由操作系统决定。同…

【项目集成Husky】

项目集成Husky 安装初始化 Husky在.husky → pre-commit文件中添加想要执行的命令 安装 使用 Husky 可以帮助你在 Git 钩子中运行脚本&#xff0c;例如在提交代码前运行测试或格式化代码pnpm add --save-dev husky初始化 Husky npx husky init这会在项目根目录下创建一个 .hu…

Arcgis国产化替代:Bigemap Pro正式发布

在数字化时代&#xff0c;数据如同新时代的石油&#xff0c;蕴含着巨大的价值。从商业决策到科研探索&#xff0c;从城市规划到环境监测&#xff0c;海量数据的高效处理、精准分析与直观可视化&#xff0c;已成为各行业突破发展瓶颈、实现转型升级的关键所在。历经十年精心打磨…