10个经典Python设计模式解析

大家好!今天咱们来聊聊Python编程中的那些“武林秘籍”——设计模式。它们就像编程界的暗号,让你的代码更加优雅、高效。让我们一起揭开这些模式的神秘面纱,看看它们在实际项目中的神奇作用吧!

1. 工厂模式(Factory Pattern)

  • 想象一下,你有个大冰箱,每次需要冰淇淋时,你都不用直接打开冷冻室,而是通过一个工厂方法来决定要哪种口味。
def create_creamy_icecream(): return CreamyIceCream()
def create_fruit_icecream(): return FruitIceCream()
class IceCreamFactory:@staticmethoddef get_icecream(kind): if kind == 'creamy':return create_creamy_icecream()elif kind == 'fruit':return create_fruit_icecream()

2. 装饰器模式(Decorator Pattern)

  • 好比给房间添加装饰,改变外观但不改变核心功能。比如,给打印语句加上颜色:
def color_decorator(func):def wrapper(color):print(f"{color} {func(color)}")return wrapper
@color_decorator
def say_hello(name): print(f"Hello, {name}")
say_hello("Python")  # 输出: Red Hello, Python

3. 单例模式(Singleton Pattern)

  • 确保一个类只有一个实例,并提供全局访问点。就像一个班级只有一个班长:
class Singleton:_instance = Nonedef __new__(cls):if not cls._instance:cls._instance = super().__new__(cls)return cls._instance
class MyClass(Singleton):pass
obj1 = MyClass()
obj2 = MyClass()  # obj1和obj2指向同一个实例

4. 观察者模式(Observer Pattern)

  • 当数据变化时,所有依赖它的对象都会得到通知。就像天气预报,一旦有新的天气数据,所有订阅者都会收到更新:
class Subject:def attach(self, observer): self.observers.append(observer)def detach(self, observer): self.observers.remove(observer)def notify(self): for observer in self.observers: observer.update()
class Observer:def update(self, data): print(f"New data: {data}")
subject = Subject()
observer1 = Observer()
subject.attach(observer1)
subject.notify()  # 输出: New data: ...

5. 策略模式(Strategy Pattern)

  • 在不同情况下使用不同的算法,而无需修改使用算法的代码。就像烹饪,根据食材选择不同的烹饪方式:
class CookingStrategy:def cook(self, ingredient): pass
class BoilingStrategy(CookingStrategy):def cook(self, ingredient): print(f"Heating {ingredient} to boil...")
class GrillingStrategy(CookingStrategy):def cook(self, ingredient): print(f"Grilling {ingredient}...")
class Kitchen:def __init__(self, strategy):self.strategy = strategydef cook(self, ingredient):self.strategy.cook(ingredient)
kitchen = Kitchen(BoilingStrategy())
kitchen.cook("water")  # 输出: Heating water to boil...

6. 适配器模式(Adapter Pattern)

  • 让不兼容的对象协同工作,就像老式电视和现代播放器之间的连接器:
class OldTV:def play(self, channel): print(f"Watching channel {channel}")
class RemoteAdapter:def __init__(self, tv):self.tv = tvdef press_button(self, command): getattr(self.tv, command)()
remote = RemoteAdapter(OldTV())
remote.press_button("play")  # 输出: Watching channel ...

7. 代理模式(Proxy Pattern)

  • 为对象提供一个替身,对原对象进行控制或包装。想象一个网站缓存:
class RemoteImage:def __init__(self, url):self.url = urldef display(self):print(f"Displaying image from {self.url}")
class LocalImageProxy(RemoteImage):def display(self):print("Loading image from cache...")super().display()

8. 迭代器模式(Iterator Pattern)

  • 遍历集合而不需要暴露其内部结构。就像翻阅书页:
class Book:def __iter__(self):self.page = 1return selfdef __next__(self):if self.page > 10:raise StopIterationresult = f"Page {self.page}"self.page += 1return result
book = Book()
for page in book: print(page)  # 输出: Page 1, Page 2, ..., Page 10

9. 命令模式(Command Pattern)

  • 将请求封装为对象,使你能够推迟或更改请求的执行。就像点餐系统:
class Command:def execute(self): pass
class Order(Command):def execute(self, item): print(f"Preparing {item}...")
class Kitchen:def execute_order(self, cmd): cmd.execute()
order = Order()
kitchen = Kitchen()
kitchen.execute_order(order)  # 输出: Preparing ...

10. 享元模式(Flyweight Pattern)

  • 通过共享对象来节约内存,减少重复。像打印海报,每个字母可以共享:
class Letter:def __init__(self, text):self.text = text
class FlyweightLetter(Letter):_instances = {}def __new__(cls, text):if text not in cls._instances:cls._instances[text] = super().__new__(cls, text)return cls._instances[text]
poster = "Python"
print([l.text for l in poster])  # 输出: ['P', 'y', 't', 'h', 'o', 'n']

以上就是10个经典的Python设计模式,掌握了它们,你的代码将会更有组织,更易于理解和维护。记住,编程不只是写代码,更是艺术创作!现在就去把这些模式运用到你的项目中,让它们大放异彩吧!

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

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

相关文章

Day23_学点儿IDEA_单元测试@Test在新module项目中失效、Jackson核心对象 ObjectMapper识别不到

版本 IntelliJ IDEA 2023.2.4 目录结构 Study(Project) ├──JavaSE(Module) │ └──xxxx └──JavaWeb(Module)└──xxxx问题 1.1 在JavaSE项目中正常可以用的单元测试Test,到了JavaWeb项目中不起作用了 1.2 解决方法 如果是新创建的项目,先…

物联网全栈智能应用实训系统

物联网全栈智能应用实训系统是一款集硬件、软件、网络、数据分析与应用开发于一体的综合性实训平台。它旨在帮助学习者全面掌握物联网技术的各个环节,从硬件设备选型、通信协议理解、软件开发、数据分析到应用部署,都能得到充分的实践锻炼。 一、产品构…

Jenkins+AWS CodeCommit(git)

问题 需要使用Jenkins搭建一套CI流,即通过git代码托管拉取代码,构建自定分支的代码,构建出jar,并进一步构建出docker镜像,并推送到docker私有库中。 准备 AWS云准备 这里假设已经在CodeCommit已经存在私有git代码仓…

Comparablae接口

在日常生经常涉及到排序的的问题,排序问题中又不得不涉及到比较的问题。在排序问题中根据不同的规则对多个对象进行比较,然后根据比较内容的不同对对象进行排序。java中的Comparable就是用来定义排序规则的接口。当要对类中的对象进行排序操作时&#xf…

CentOS7上pt-archiver工具进行数据库表归档——筑梦之路

pt-archiver 是一个用于 MySQL 数据归档和清理的强大工具。它可以将旧数据从原表移动到归档表,同时保持原表的性能不受影响。 前提条件 表有做分区或者有时间字段 在线安装 sudo yum install https://repo.percona.com/yum/percona-release-latest.noarch.rpm sud…

View-Consistent 3D Editing with Gaussian Splatting

View-Consistent 3D Editing with Gaussian Splatting 使用高斯溅射进行视图一致的3D编辑 Yuxuan Wang 王宇轩11Xuanyu Yi 易轩宇11Zike Wu 吴子可11Na Zhao 赵娜22Long Chen 龙宸33Hanwang Zhang 张汉旺1144 Abstract 摘要 View-Consistent 3D Editing with Gaussian Sp…

Zookeeper与Kafka消息队列

目录 一、Zookeeper 1、zookeeper简介 2、zookeeper的特点 3、zookeeper的工作模式跟工作机制 3.1 工作模式: 3.2工作机制:​编辑 4、zookeeper应用场景及选举机制 4.1 应用场景: 4.2 选举机制: 4.2.1第一次启动选举机制…

每日Bug汇总--Day05

Bug汇总—Day05 一、项目运行报错 二、项目运行Bug 1、**问题描述:**前端将从后台查询的数据作为参数进行get请求,参数为空 原因分析: 这种写法可能只支全局的参数调用方法的传参响应 代码实现 if (this.jishiName) {this.$http({url…

JAVA集合ArrayList

目录 ArrayList概述 add(element) 用法 add(index, element)用法 remove(element)用法 remove(index)用法 get(index)用法 set(index,element) 练习 test1 定义一个集合,添加字符串,并进行遍历&…

什么是塔式服务器?

塔式服务器是服务器类型中比较常见的一种,通常是垂直和水平盒式形状的服务器,和台式塔式计算机比较相似,塔式服务器可以单独放置在通用的办公环境当中,塔式服务器的机箱机构也比其他的服务器要大,有着足够的内部硬盘和…

解析OceanBase v4.2磁盘数据文件支持按需扩展的功能

前言 若你日常习惯使用MySQL,那当使用过Oceanbase分布式数据库后,也许会对OceanBase的磁盘数据文件样式产生这样的疑问:为何储存数据仅用一个大的block_file文件呢? 简要分析下,OceanBase是通过Linux系统调用falloca…

HarmonyOS实战开发-音视频录制、如何实现音频录制和视频录制功能的应用

介绍 音视频录制应用是基于AVRecorder接口开发的实现音频录制和视频录制功能的应用,音视频录制的主要工作是捕获音频信号,接收视频信号,完成音视频编码并保存到文件中,帮助开发者轻松实现音视频录制功能,包括开始录制…

启动Unity发布的exe并且添加启动参数

启动Unity发布的exe并且添加启动参数 在启动Unity的时候添加一些启动的参数。 代码解释 在启动的时候获取的启动参数如果没有获取到正确的启动参数那么就退出程序,这个代码仅仅在发布到windows之后才会生效,在编辑器下这个代码虽然会获取到参数但是不能…

【YOLOv9改进[损失函数]】使用MPDIou回归损失函数帮助YOLOv9模型更优秀

本文中,第一部分概述了各种回归损失函数,当然也包括了今天的主角MPDIou。第二部分内容为在YOLOv9中使用MPDIou回归损失函数的方法。 1 回归损失函数(Bounding Box Regression Loss) 边界框回归损失计算的方法包括GIoU、DIoU、CI…

微服务下使用sentinel进行服务熔断

首先引入sentinel对应依赖 <dependency><groupId>com.alibaba.cloud</groupId><artifactId>spring-cloud-starter-alibaba-sentinel</artifactId> </dependency>下面是示例service代码,通过openFeign完成服务调用 Service public class …

低频电磁仿真 | 新能源汽车性能提升的利器

永磁同步电机 新能源汽车的心脏 近年来&#xff0c;全球变暖的趋势日益加剧&#xff0c;极端天气事件层出不穷&#xff0c;这些现象都反映出当前气候形势的严峻性。为了应对这一全球性挑战&#xff0c;各国纷纷采取行动&#xff0c;制定了一系列降碳、减碳的措施。中国在2020年…

ElasticView一款ElasticSearch的web可视化工具

ElasticView 是一款用来监控ElasticSearch状态和操作ElasticSearch索引的web可视化工具。它由golang开发而成&#xff0c;具有部署方便&#xff0c;占用内存小等优点 ElasticSearch连接树管理&#xff08;更方便的切换测试/生产环境&#xff09;支持权限管理支持sql转换成dsl语…

Java搭配H5实现前后端交互评论功能

前言&#xff1a; 最近有个朋友有偿让我帮他们将这个评论组件整合到他们的静态网页当中&#xff0c;并实现数据持久化。后来他觉得太麻烦&#xff0c;就放弃了。尽管没有拿到相应的报酬&#xff0c;但只是花了短短的时间写完了这个简单功能&#xff0c;并有机会将其分享给大家。…

从IoTDB的发展回顾时序数据库演进史

面向工业物联网时代&#xff0c;以 IoTDB 为代表的时序数据库加速发展。 时序数据的主要产生来源之一是设备与传感器&#xff0c;具有监测点多、采样频率高、存储数据量大等多类不同于其他数据类型的特性&#xff0c;从而导致数据库在实现高通量写入、存储成本、实时查询等多个…

第G2周:人脸图像生成(DCGAN)

第G2周&#xff1a;人脸图像生成&#xff08;DCGAN&#xff09; 第G2周&#xff1a;人脸图像生成&#xff08;DCGAN&#xff09;一、前言二、我的环境三、代码实现1、导入第三方库2、设置超参数3、导入数据 四、定义模型4.1 初始化权重4.2 定义生成器4.3 定义鉴别器 五、训练模…