Python设计模式:克隆模式

1. 什么是克隆模式

克隆模式的核心思想是通过复制一个已有的对象(原型)来创建一个新的对象(克隆)。这种方式可以避免重复的初始化过程,从而提高效率。克隆模式通常涉及以下几个方面:

  1. 原型对象:一个已经存在的对象,作为克隆的基础。
  2. 克隆方法:用于复制原型对象的具体方法,通常实现为一个 clone 方法。
  3. 深拷贝与浅拷贝
    • 浅拷贝:创建一个新对象,但不复制嵌套对象的引用。新对象与原对象共享嵌套对象。
    • 深拷贝:创建一个新对象,并递归地复制所有嵌套对象,确保新对象与原对象完全独立。

克隆模式在许多开发场景中都非常有用,以下是一些常见的应用场景:

  1. 图形编辑器:用户可能需要创建多个相似的图形对象(如圆形、矩形等),使用克隆模式可以快速复制现有图形,避免重复的初始化过程。
  2. 游戏开发:在游戏中,克隆模式可以用于创建多个相似的游戏角色或物体,例如创建多个相同类型的敌人或道具。
  3. 文档处理:在文本编辑器或文档处理软件中,用户可能需要插入多个相似格式的段落或文本块,通过克隆模式可以快速复制现有段落,保持格式一致性。
  4. 配置管理:在应用程序中,配置对象可能需要被多次使用。通过克隆模式,可以创建配置对象的副本,以便在不同的上下文中使用,而不需要重新加载或初始化配置。
  5. 状态恢复:在某些应用中,可能需要保存对象的状态并在需要时恢复。克隆模式可以帮助创建对象的快照,以便在后续操作中恢复到之前的状态。
  6. 原型设计模式:克隆模式是原型设计模式的一部分,适用于需要创建大量相似对象的场景。
  7. 数据处理:在数据处理和分析应用中,克隆模式可以用于创建数据记录的副本,以便在处理过程中进行修改而不影响原始数据。

2. 浅拷贝与深拷贝

创建一个 Person 类,该类包含多种属性,包括基本数据类型(如整数、字符串、浮点数)和嵌套对象(如列表和字典)。具体属性如下:

  • name:字符串类型,表示人的名字。
  • age:整数类型,表示人的年龄。
  • height:浮点数类型,表示人的身高。
  • hobbies:列表类型,表示人的爱好(嵌套对象)。
  • address:字典类型,表示人的地址信息(嵌套对象)。
import copyclass Person:def __init__(self, name, age, height, hobbies, address):self.name = name          # 字符串self.age = age            # 整数self.height = height      # 浮点数self.hobbies = hobbies    # 嵌套对象(列表)self.address = address    # 嵌套对象(字典)# 创建一个原始对象
original = Person(name="Alice",age=30,height=5.5,hobbies=["Reading", "Traveling"],address={"city": "New York", "zip": "10001"}
)# 使用浅拷贝创建一个新对象
shallow_copied = copy.copy(original)# 使用深拷贝创建一个新对象
deep_copied = copy.deepcopy(original)# 修改原始对象的基本数据类型属性
original.age = 35
original.height = 6.0# 修改原始对象的嵌套对象
original.hobbies.append("Cooking")
original.address["city"] = "Los Angeles"# 输出结果
print("Original:")
print(f"Name: {original.name}, Age: {original.age}, Height: {original.height}")
print(f"Hobbies: {original.hobbies}, Address: {original.address}")print("\nShallow Copied:")
print(f"Name: {shallow_copied.name}, Age: {shallow_copied.age}, Height: {shallow_copied.height}")
print(f"Hobbies: {shallow_copied.hobbies}, Address: {shallow_copied.address}")print("\nDeep Copied:")
print(f"Name: {deep_copied.name}, Age: {deep_copied.age}, Height: {deep_copied.height}")
print(f"Hobbies: {deep_copied.hobbies}, Address: {deep_copied.address}")
Original:
Name: Alice, Age: 35, Height: 6.0
Hobbies: ['Reading', 'Traveling', 'Cooking'], Address: {'city': 'Los Angeles', 'zip': '10001'}Shallow Copied:
Name: Alice, Age: 30, Height: 5.5
Hobbies: ['Reading', 'Traveling', 'Cooking'], Address: {'city': 'New York', 'zip': '10001'}Deep Copied:
Name: Alice, Age: 30, Height: 5.5
Hobbies: ['Reading', 'Traveling'], Address: {'city': 'New York', 'zip': '10001'}

浅拷贝与深拷贝的表现

  1. 基本数据类型
    • 在浅拷贝和深拷贝的情况下,基本数据类型的属性(如 ageheight)是独立的。修改原始对象的这些属性不会影响克隆对象的相应属性。
  2. 嵌套对象
    • 浅拷贝:对于 hobbies 列表和 address 字典,浅拷贝会创建一个新的 Person 对象,但嵌套对象的引用仍然指向原始对象中的嵌套对象。因此,修改原始对象的嵌套对象会影响到浅拷贝对象。
    • 深拷贝:对于 hobbies 列表和 address 字典,深拷贝会创建一个新的 Person 对象,并递归地复制所有嵌套对象。因此,修改原始对象的嵌套对象不会影响到深拷贝对象。
  • 原始对象ageheight 属性被修改,显示为 356.0
  • 浅拷贝对象ageheight 属性保持不变,仍然是 305.5。但是,hobbies 列表的内容反映了原始对象的变化,因为它们共享同一个列表对象。
  • 深拷贝对象ageheight 属性也保持不变,hobbies 列表和 address 字典的内容与原始对象的变化无关,保持了克隆时的状态。

3. 例子 1:图形编辑器中的克隆模式

在实际开发中,克隆模式常用于图形编辑器等应用程序中。在这些应用程序中,用户可能需要创建多个相似的图形对象(如圆形、矩形等),而这些对象的属性可能会有所不同。使用克隆模式可以简化对象的创建过程,提高效率。
将创建一个 Circle 类,表示一个圆形对象。该类将包含圆心坐标、半径和颜色等属性,并提供克隆功能。

import copyclass Circle:def __init__(self, x, y, radius, color):self.x = x                # 圆心的 x 坐标self.y = y                # 圆心的 y 坐标self.radius = radius      # 半径self.color = color        # 颜色def clone(self):"""克隆方法,使用深拷贝"""return copy.deepcopy(self)def __str__(self):return f"Circle(x={self.x}, y={self.y}, radius={self.radius}, color='{self.color}')"# 创建一个原始圆形对象
original_circle = Circle(x=10, y=20, radius=5, color="red")# 使用克隆方法创建一个新对象
cloned_circle = original_circle.clone()# 修改克隆对象的属性
cloned_circle.x = 15
cloned_circle.color = "blue"# 输出结果
print("Original Circle:", original_circle)  # 输出: Circle(x=10, y=20, radius=5, color='red')
print("Cloned Circle:", cloned_circle)      # 输出: Circle(x=15, y=20, radius=5, color='blue')
  • x:表示圆心的 x 坐标,类型为整数。
  • y:表示圆心的 y 坐标,类型为整数。
  • radius:表示圆的半径,类型为浮点数。
  • color:表示圆的颜色,类型为字符串。
  • clone 方法:该方法使用 copy.deepcopy() 来创建圆形对象的克隆,确保新对象与原对象完全独立。
  • 创建一个原始圆形对象 original_circle,然后使用 clone 方法创建一个克隆对象 cloned_circle
  • 修改克隆对象的属性后,输出原始对象和克隆对象的属性,观察它们的变化。

优点

  • 提高效率:通过克隆现有对象,用户可以快速创建多个相似的图形,避免重复的初始化过程。
  • 简化管理:克隆模式使得对象的管理更加简单,用户可以轻松地修改克隆对象的属性,而不影响原始对象。

4. 例子 2:文本编辑器中的克隆模式

在实际开发中,克隆模式也常用于文本编辑器等应用程序中。在这些应用程序中,用户可能需要创建多个相似的文本格式对象(如段落、标题等),而这些对象的属性可能会有所不同。使用克隆模式可以简化对象的创建过程,提高效率。
将创建一个 Paragraph 类,表示一个段落对象。该类将包含文本内容、字体大小、颜色和对齐方式等属性,并提供克隆功能。

import copyclass Paragraph:def __init__(self, text, font_size, color, alignment):self.text = text                  # 文本内容self.font_size = font_size        # 字体大小self.color = color                # 颜色self.alignment = alignment        # 对齐方式def clone(self):"""克隆方法,使用深拷贝"""return copy.deepcopy(self)def __str__(self):return f"Paragraph(text='{self.text}', font_size={self.font_size}, color='{self.color}', alignment='{self.alignment}')"# 创建一个原始段落对象
original_paragraph = Paragraph(text="This is a sample paragraph.",font_size=12,color="black",alignment="left"
)# 使用克隆方法创建一个新对象
cloned_paragraph = original_paragraph.clone()# 修改克隆对象的属性
cloned_paragraph.text = "This is a cloned paragraph."
cloned_paragraph.font_size = 14
cloned_paragraph.color = "blue"
cloned_paragraph.alignment = "center"# 输出结果
print("Original Paragraph:", original_paragraph)  # 输出: Paragraph(text='This is a sample paragraph.', font_size=12, color='black', alignment='left')
print("Cloned Paragraph:", cloned_paragraph)      # 输出: Paragraph(text='This is a cloned paragraph.', font_size=14, color='blue', alignment='center')
  • text:表示段落的文本内容,类型为字符串。
  • font_size:表示段落的字体大小,类型为整数。
  • color:表示段落的颜色,类型为字符串。
  • alignment:表示段落的对齐方式,类型为字符串(如 “left”、“center”、“right”)。
  • clone 方法:该方法使用 copy.deepcopy() 来创建段落对象的克隆,确保新对象与原对象完全独立。

优点

  • 提高效率:通过克隆现有对象,用户可以快速创建多个相似的段落,避免重复的初始化过程。
  • 简化管理:克隆模式使得对象的管理更加简单,用户可以轻松地修改克隆对象的属性,而不影响原始对象。

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

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

相关文章

逻辑漏洞之越权访问总结

什么是越权访问漏洞? “越权访问漏洞” 是 “逻辑漏洞” 的一种,是由于网站系统的权限校验的逻辑不够严谨,没有对用户权限进行严格的身份鉴别,导致普通权限的用户做到了其它普通用户或管理员才能完成的操作,称之为“越…

超短波通信模拟设备:增强通信能力的关键工具

在全球信息化战争的背景下,通信系统扮演着至关重要的角色。为确保通信系统的稳定性和抗干扰能力,超短波通信模拟设备应运而生,为军事训练和通信干扰任务提供强大的支持。 设备特点及优势 便携性:设备体积小、重量轻,…

C++STL——容器-vector(含部分模拟实现,即地层实现原理)(含迭代器失效问题)

目录 容器——vector 1.构造 模拟实现 2.迭代器 模拟实现: ​编辑 3.容量 模拟实现: 4.元素的访问 模拟实现 5.元素的增删查改 迭代器失效问题: 思考问题 【注】:这里的模拟实现所写的参数以及返回值,都是…

Ubuntu交叉编译器工具链安装

声明 本博客所记录的关于正点原子i.MX6ULL开发板的学习笔记,(内容参照正点原子I.MX6U嵌入式linux驱动开发指南,可在正点原子官方获取正点原子Linux开发板 — 正点原子资料下载中心 1.0.0 文档),旨在如实记录我在学校学…

Tomcat 部署 Jenkins.war 详细教程(含常见问题解决)

在Tomcat中部署Jenkins.war文件是一个相对简单的过程,以下是详细步骤: 1. 准备工作 确保已安装JDK:Jenkins需要Java环境,建议安装JDK 8或更高版本。 下载Jenkins.war:https://pan.quark.cn/s/c4fd7711a1b3 下载Tomc…

DAY46 动态规划Ⅸ 股票问题Ⅱ

188. 买卖股票的最佳时机 IV - 力扣&#xff08;LeetCode&#xff09; class Solution { public:int maxProfit(int k, vector<int>& prices) {if(prices.size()0) return 0;vector<vector<int>>dp(prices.size(),vector<int>(2*k1,0));for(int i…

4月2日工作日志

一个朴实无华的目录 今日学习内容&#xff1a;1.UIAbility生命周期2.默认启动页面设置3.同模块唤起ability 今日实操内容&#xff1a; 今日学习内容&#xff1a; 1.UIAbility生命周期 2.默认启动页面设置 3.同模块唤起ability 今日实操内容&#xff1a; 通过分组件文件&#…

鸿蒙学习笔记(4)-Radio组件、弹框组件、组件内部状态、工具类

一、Radio组件 &#xff08;1&#xff09;简述 创建单选框组件。接收一个RadioOptions类型对象参数。 名称类型必填说明valuestring是 当前单选框的值。 groupstring是 当前单选框的所属群组名称&#xff0c;相同group的Radio只能有一个被选中。 indicatorType12RadioIndica…

111.在 Vue 3 中使用 OpenLayers 实现动态曲线流动图(类似 ECharts 迁徙状态)

在数据可视化领域&#xff0c;ECharts 提供的 迁徙图&#xff08;流动图&#xff09; 是一种直观展示数据流动的方式&#xff0c;如人口迁徙、物流流向等。我们可以使用 OpenLayers 结合 Vue 3 来实现类似的 动态曲线流动图&#xff0c;从而在 Web GIS 项目中提供更生动的可视化…

全栈开发项目实战——AI智能聊天机器人

文章目录 一&#xff1a;项目技术栈和代码分析1.前端技术栈&#xff08;1&#xff09;HTML&#xff08;index.html&#xff09;&#xff1a;&#xff08;2&#xff09;CSS&#xff08;styles.css&#xff09;&#xff1a;&#xff08;3&#xff09;JavaScript&#xff08;scrip…

无人机机体结构设计要点与难点!

一、无人机机体结构设计要点 1. 类型与应用场景匹配 固定翼无人机&#xff1a;需优化机翼升阻比&#xff0c;采用流线型机身降低气动阻力&#xff08;如大展弦比机翼设计&#xff09;。 多旋翼无人机&#xff1a;注重轻量化框架和对称布局&#xff08;如四轴/六轴碳纤维机…

eBest AI智能报表:用自然语言对话解锁企业数据生产力

告别传统数据迷宫&#xff0c;让业务洞察"开口即得" 【数据价值被困在系统迷宫中】​ 在数字化转型的深水区&#xff0c;80%的企业正被数据孤岛和越来越多&#xff0c;也越来越复杂的系统所困扰。 • 操作黑洞&#xff1a;用户平均通过6次筛选和层级跳转才能触达目标…

Linux 编程环境

文章目录 VimGCCGDBMake Vim Vim GCC GCC&#xff08;GNU Compiler Collection&#xff09;是一款编译语言编译器&#xff0c;此项目最早由GNU计划的发起者理查德 斯托曼开始实施。第一版GCC于1987年发行&#xff0c;最初的GCC代表GNU C Compiler&#xff0c;即GNU的C语言编…

JSONP跨域访问漏洞

一、漏洞一:利用回调GetCookie <?php$conn new mysqli(127.0.0.1,root,root,learn) or die("数据库连接不成功"); $conn->set_charset(utf8); $sql "select articleid,author,viewcount,creattime from learn3 where articleid < 5"; $result…

JuiceFS vs HDFS,最简单的 JuiceFS 入门

你好,我是 shengjk1,多年大厂经验,努力构建 通俗易懂的、好玩的编程语言教程。 欢迎关注!你会有如下收益: 了解大厂经验拥有和大厂相匹配的技术等希望看什么,评论或者私信告诉我! 文章目录 一、背景二、JuiceFS 入门2.1 核心特性2.2 JuiceFS 架构2.3 JuiceFS 如何存储文…

音频进阶学习二十四——IIR滤波器设计方法

文章目录 前言一、滤波器设计要求1.选频滤波器种类2.通带、阻带、过度带3.滤波器设计指标 二、IIR滤波器的设计过程1.设计方法2.常见的模拟滤波器设计1&#xff09;巴特沃斯滤波器&#xff08;Butterworth Filter&#xff09;2&#xff09;切比雪夫滤波器&#xff08;Chebyshev…

vue3源码分析 -- runtime

runtime运行时&#xff0c;主要在packages/runtime-core目录下&#xff0c;核心提供了h、render等函数。在理解它们之前&#xff0c;我们需要了解下HTML DOM 树和虚拟 DOM等概念 HTML DOM 树 通过节点构成的一个树形结构&#xff0c;我们称为HTML DOM节点树。DOM 文档里面做了…

清明假期在即

2025年4月2日&#xff0c;6~22℃&#xff0c;一般 遇见的事&#xff1a;这么都是清明出去玩&#xff1f;你们不扫墓的么。 感受到的情绪&#xff1a;当精力不放在一个人身上&#xff0c;你就会看到很多人&#xff0c;其实可以去接触的。 反思&#xff1a;抖音上那么多不幸和幸…

tomcat 目录结构组成

文章目录 背景文件结构层级一些常用的路径 背景 现在非常多的 java web 服务部署在 linux 服务器中&#xff0c;我们服务器中的 tomcat 会有各种文件路径&#xff0c;看下它有哪些文件 文件结构层级 ├── bin/ # 核心脚本和启动文件 ├── conf/ # …

多层内网渗透测试虚拟仿真实验环境(Tomcat、ladon64、frp、Weblogic、权限维持、SSH Server Wrapper后门)

在线环境:https://www.yijinglab.com/ 拓扑图 信息收集 IP地址扫描 确定目标IP为10.1.1.121 全端口扫描 访问靶机8080端口,发现目标是一个Tomcat服务,版本