【设计模式】单例模式、工厂模式、策略模式、观察者模式、装饰器模式

2024-08-24 14:28

本文主要是介绍【设计模式】单例模式、工厂模式、策略模式、观察者模式、装饰器模式,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1 单例模式
2 工厂模式
3 策略模式
4 观察者模式
5 装饰器模式

1 单例模式

class Singleton:"""单例模式:确保一个类只有一个实例,并提供一个全局访问点。在需要全局状态或者需要频繁创建和销毁实例会导致性能问题时非常有用。"""_instance = Nonedef __new__(cls, *args, **kwargs):"""创建实例时调用,确保只有一个实例。:param args: 位置参数:param kwargs: 关键字参数:return: 唯一实例"""if cls._instance is None:cls._instance = super(Singleton, cls).__new__(cls)return cls._instancedef __init__(self, value=None):"""初始化实例属性。:param value: 初始化值"""# 使用一个类属性来检查实例是否已初始化if not hasattr(self, '_initialized'):self.value = valueself._initialized = True# 示例用法
singleton1 = Singleton(10)
singleton2 = Singleton(20)print(singleton1.value)  # 输出: 10
print(singleton2.value)  # 输出: 10
print(singleton1 is singleton2)  # 输出: True

2 工厂模式

class AnimalFactory:"""工厂模式用于创建对象,而不需要指定将要创建的具体类。这在需要将对象创建的代码与使用对象的代码分离时非常有用,提高了代码的灵活性和扩展性。工厂模式提供了一个方法来创建对象,客户端代码只需调用这个方法,而无需了解如何创建对象的详细信息。"""@staticmethoddef create_animal(animal_type):"""根据指定的动物类型创建并返回对应的动物对象。:param animal_type: 要创建的动物类型('dog' 或 'cat'):return: 对应的动物对象(Dog 或 Cat):raises ValueError: 如果指定的 animal_type 无效,则抛出异常"""if animal_type == 'dog':return Dog()  # 创建并返回 Dog 类的实例elif animal_type == 'cat':return Cat()  # 创建并返回 Cat 类的实例else:raise ValueError(f"Unknown animal type: {animal_type}")  # 如果 animal_type 无效,抛出异常# 示例用法
dog = AnimalFactory.create_animal('dog')
print(dog)  # 输出: <__main__.Dog object at ...># 如果需要一个 Cat 实例
cat = AnimalFactory.create_animal('cat')
print(cat)  # 输出: <__main__.Cat object at ...>

3 策略模式

class Strategy:"""策略模式定义了一系列算法,并将每一个算法封装起来,使他们可以互换。这在需要根据不同情况使用不同算法或行为时非常有用"""def execute(self):"""执行策略的方法,具体策略类需要实现此方法。:return: 策略的执行结果"""passclass ConcreateStrategyA(Strategy):"""具体策略类A:实现了 Strategy 接口,定义了特定的策略行为。"""def execute(self):"""实现具体的策略行为。:return: 表示具体策略 A 的执行结果"""return "ConcreateStrategyA"class Context:"""上下文类:维护一个 Strategy 对象的引用,并允许在运行时设置或更改策略。上下文类依赖于策略接口,并将策略的执行委托给具体的策略类。"""def __init__(self, strategy: Strategy):"""初始化上下文对象时传入一个策略对象。:param strategy: 一个 Strategy 类型的策略对象"""self._strategy = strategydef set_strategy(self, strategy: Strategy):"""设置或更改策略对象。:param strategy: 一个 Strategy 类型的策略对象"""self._strategy = strategydef do_action(self):"""执行当前策略的行为。:return: 策略的执行结果"""return self._strategy.execute()# 示例用法
strategy_a = ConcreateStrategyA()  # 创建具体策略 A 的实例
context = Context(strategy_a)  # 使用策略 A 初始化上下文对象
print(context.do_action())  # 输出: ConcreateStrategyA# 可以更改策略
class ConcreateStrategyB(Strategy):"""具体策略类B:实现了 Strategy 接口,定义了另一种策略行为。"""def execute(self):"""实现具体的策略行为。:return: 表示具体策略 B 的执行结果"""return "ConcreateStrategyB"strategy_b = ConcreateStrategyB()  # 创建具体策略 B 的实例
context.set_strategy(strategy_b)  # 将上下文的策略更改为策略 B
print(context.do_action())  # 输出: ConcreateStrategyB

4 观察者模式

class Subject:"""观察者模式定义了对象之间一对多依赖关系,当一个对象状态发送改变时,所有依赖于他的对象都会得到通知并自动更新这在需要实现时间驱动的系统时非常有用"""def __init__(self):"""初始化主题对象,创建一个空的观察者列表。"""self._observers = []  # 存储所有注册的观察者对象def attach(self, observer):"""将一个新的观察者对象添加到观察者列表中。:param observer: 需要注册的观察者对象"""self._observers.append(observer)def detach(self, observer):"""从观察者列表中移除一个观察者对象。:param observer: 需要移除的观察者对象"""self._observers.remove(observer)def notify(self):"""通知所有观察者,调用它们的 update 方法。"""for observer in self._observers:observer.update()  # 调用每个观察者的 update 方法class Observer:"""观察者(Observer)抽象类:定义了一个更新接口,具体的观察者类需要实现该接口以响应主题的通知。"""def update(self):"""当主题通知时,调用此方法以更新观察者的状态。具体观察者类需要实现此方法。"""passclass ConcreateObserverA(Observer):"""具体观察者A(ConcreateObserverA)类:实现了 Observer 接口,并定义了具体的更新行为。"""def update(self):"""实现观察者的更新行为,当主题通知时调用。"""print('ConcreateObserverA notified')  # 打印通知信息# 示例用法
subject = Subject()  # 创建主题对象
observer_a = ConcreateObserverA()  # 创建具体观察者A的实例
subject.attach(observer_a)  # 将观察者A注册到主题中# 当主题状态发生变化时,通知所有观察者
subject.notify()  # 输出: ConcreateObserverA notified

5 装饰器模式

class Component:"""装饰器模式允许所有用户在不修改对象的情况下,向对象添加新的龚这在需要动态地给对象添加功能时非常有用组件抽象类(Component):定义一个接口,用于所有具体组件和装饰器类。装饰器模式允许在不修改对象本身的情况下,动态地为对象添加新的功能。这在需要扩展对象的功能且不希望影响其他对象时非常有用。"""def do_something(self):"""执行某种操作的方法。具体组件和装饰器类都需要实现这个方法。"""passclass ConcreteComponent(Component):"""具体组件类(ConcreteComponent):实现了 Component 接口,定义了具体的行为。装饰器将为这个类动态地添加额外的功能。"""def do_something(self):"""实现具体的操作。在装饰器模式中,装饰器将在此操作的基础上添加额外的功能。"""print("ConcreteComponent's behavior")class DecoratorA(Component):"""具体装饰器类A(DecoratorA):继承自 Component 并包含一个 Component 对象的引用。通过组合的方式,将额外的功能添加到该组件中。"""def __init__(self, component: Component):"""初始化装饰器,并将一个 Component 对象传入。:param component: 被装饰的组件对象"""self._component = component  # 持有被装饰组件的引用def do_something(self):"""执行被装饰组件的原有操作,并添加额外的行为。"""self._component.do_something()  # 调用被装饰组件的原有操作self.additional_behavior()  # 添加装饰器A的额外行为def additional_behavior(self):"""定义装饰器A的额外行为。此方法在装饰器的 do_something 方法中调用,作为对原有操作的扩展。"""print('Additional behavior of DecoratorA')# 示例用法
component = ConcreteComponent()  # 创建具体组件实例
decorator = DecoratorA(component)  # 使用 DecoratorA 装饰组件
decorator.do_something()  # 输出: ConcreteComponent's behavior
#       Additional behavior of DecoratorA

这篇关于【设计模式】单例模式、工厂模式、策略模式、观察者模式、装饰器模式的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1102736

相关文章

Python装饰器之类装饰器详解

《Python装饰器之类装饰器详解》本文将详细介绍Python中类装饰器的概念、使用方法以及应用场景,并通过一个综合详细的例子展示如何使用类装饰器,希望对大家有所帮助,如有错误或未考虑完全的地方,望不... 目录1. 引言2. 装饰器的基本概念2.1. 函数装饰器复习2.2 类装饰器的定义和使用3. 类装饰

SpringBoot基于配置实现短信服务策略的动态切换

《SpringBoot基于配置实现短信服务策略的动态切换》这篇文章主要为大家详细介绍了SpringBoot在接入多个短信服务商(如阿里云、腾讯云、华为云)后,如何根据配置或环境切换使用不同的服务商,需... 目录目标功能示例配置(application.yml)配置类绑定短信发送策略接口示例:阿里云 & 腾

Nginx location匹配模式与规则详解

《Nginxlocation匹配模式与规则详解》:本文主要介绍Nginxlocation匹配模式与规则,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、环境二、匹配模式1. 精准模式2. 前缀模式(不继续匹配正则)3. 前缀模式(继续匹配正则)4. 正则模式(大

redis过期key的删除策略介绍

《redis过期key的删除策略介绍》:本文主要介绍redis过期key的删除策略,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录第一种策略:被动删除第二种策略:定期删除第三种策略:强制删除关于big key的清理UNLINK命令FLUSHALL/FLUSHDB命

SpringRetry重试机制之@Retryable注解与重试策略详解

《SpringRetry重试机制之@Retryable注解与重试策略详解》本文将详细介绍SpringRetry的重试机制,特别是@Retryable注解的使用及各种重试策略的配置,帮助开发者构建更加健... 目录引言一、SpringRetry基础知识二、启用SpringRetry三、@Retryable注解

MySQL 分区与分库分表策略应用小结

《MySQL分区与分库分表策略应用小结》在大数据量、复杂查询和高并发的应用场景下,单一数据库往往难以满足性能和扩展性的要求,本文将详细介绍这两种策略的基本概念、实现方法及优缺点,并通过实际案例展示如... 目录mysql 分区与分库分表策略1. 数据库水平拆分的背景2. MySQL 分区策略2.1 分区概念

Linux系统配置NAT网络模式的详细步骤(附图文)

《Linux系统配置NAT网络模式的详细步骤(附图文)》本文详细指导如何在VMware环境下配置NAT网络模式,包括设置主机和虚拟机的IP地址、网关,以及针对Linux和Windows系统的具体步骤,... 目录一、配置NAT网络模式二、设置虚拟机交换机网关2.1 打开虚拟机2.2 管理员授权2.3 设置子

SpringBoot如何通过Map实现策略模式

《SpringBoot如何通过Map实现策略模式》策略模式是一种行为设计模式,它允许在运行时选择算法的行为,在Spring框架中,我们可以利用@Resource注解和Map集合来优雅地实现策略模式,这... 目录前言底层机制解析Spring的集合类型自动装配@Resource注解的行为实现原理使用直接使用M

C#原型模式之如何通过克隆对象来优化创建过程

《C#原型模式之如何通过克隆对象来优化创建过程》原型模式是一种创建型设计模式,通过克隆现有对象来创建新对象,避免重复的创建成本和复杂的初始化过程,它适用于对象创建过程复杂、需要大量相似对象或避免重复初... 目录什么是原型模式?原型模式的工作原理C#中如何实现原型模式?1. 定义原型接口2. 实现原型接口3

大数据spark3.5安装部署之local模式详解

《大数据spark3.5安装部署之local模式详解》本文介绍了如何在本地模式下安装和配置Spark,并展示了如何使用SparkShell进行基本的数据处理操作,同时,还介绍了如何通过Spark-su... 目录下载上传解压配置jdk解压配置环境变量启动查看交互操作命令行提交应用spark,一个数据处理框架