Python:设计模式之代理模式

简介: Python:设计模式之代理模式

一、代理模式

代理,通常就是一个介于寻求方和提供方之间的中介系统

设计模式中,代理充当实际对象接口的类

二、使用场景

1、以简单的方式表示一个复杂系统

2、提高现有实际对象的安全性

3、为不同服务器上的远程对象提供本地接口

4、为消耗大量内存的对象提供一个轻量级的句柄

三、代理模式的优点

1、代理模式可以通过缓存笨重的对象或频繁访问的对象来提高应用程序的性能

2、代理还提供对于真实主题的访问授权

3、远程代理还便于与可用作网络连接和数据库连接的远程服务器进行交互,并可用于监视系统

四、3个主要参与者

1、代理:控制对真实主题类的访问的类

2、主题/真实主题:主题是定义真实主题和代理相类似的接口,真实主题是主题的实现,提供真正功能,由客户端使用

3、客户端:访问要完成工作的代理类

五、代理类的类型

1、虚拟代理:如果一个对象实例化后会占用大量内存的话,可以先利用占位符来表示

2、远程代理:给卫浴远程服务器或不同地址空间上的实际对象提供本地表示

3、保护代理:能够控制真实对象的铭感对象的访问

4、智能代理:在访问时插入其他操作

六、代码示例

1、经纪人作为演员的代理人,安排演员的行程

# -*- coding: utf-8 -*-

class Actor(object):
    def __init__(self):
        self.is_empty = True

    def show_film(self):
        self.is_empty = False
        print(type(self).__name__, "show_film")

    def listen_music(self):
        self.is_empty = True
        print(type(self).__name__, "listen_music")


class Agent(object):
    def __init__(self):
        self.actor = Actor()

    def work(self):
        if self.actor.is_empty:
            self.actor.show_film()
        else:
            self.actor.listen_music()


if __name__ == '__main__':
    agent = Agent()
    agent.work()
    agent.work()
"""
Actor show_film
Actor listen_music
"""

2、通过借记卡代理银行完成支付工作

# -*- coding: utf-8 -*-


from abc import ABC, abstractmethod


# 支付接口
class Payment(ABC):
@abstractmethod
def do_pay(self):
pass


# 银行类:真实主题
class Bank(Payment):
def check_account(self):
print("账户检查中...")
return True

def do_pay(self):
self.check_account()
print("银行结算完成")


# 银行类的代理
class DebitCard(Payment):
def __init__(self):
self.bank = Bank()

def do_pay(self):
print("借记卡即将去银行支付")
self.bank.do_pay()
print("借记卡完成银行支付")


# 客户端
class You(object):
def __init__(self):
self.debit_card = DebitCard()

def make_payment(self):
print("借记卡支付开始")
self.debit_card.do_pay()
print("借记卡支付结束")


if name == '__main__':
you = You()
you.make_payment()
"""
借记卡支付开始
借记卡即将去银行支付
账户检查中...
银行结算完成
借记卡完成银行支付
借记卡支付结束
"""

七、门面模式和代理模式比较

代理模式 门面模式
为其他对象提供了代理或占位符,以控制对原始对象的访问 为类的大型子系统提供了一个接口
代理对象具有与其目标对象相同的接口,并保存有目标对象的引用 实现了子系统之间的通信和依赖性的最小化
充当客户端和被封装对象之间的中介 门面对象提供了单一的简单接口
            </div>
目录
相关文章
|
安全 网络安全 数据安全/隐私保护
ssl证书认证失败的原因和解决办法
ssl证书认证失败的原因和解决办法
|
8月前
|
人工智能 文字识别 异构计算
SmolDocling:256M多模态小模型秒转文档!开源OCR效率提升10倍
SmolDocling 是一款轻量级的多模态文档处理模型,能够将图像文档高效转换为结构化文本,支持文本、公式、图表等多种元素识别,适用于学术论文、技术报告等多类型文档。
776 1
SmolDocling:256M多模态小模型秒转文档!开源OCR效率提升10倍
|
编解码 网络协议 前端开发
如何实现Android平台GB28181设备接入模块按需打开摄像头并回传数据
后台采集摄像头,如果想再进一步扩展,可以把android平台gb28181的camera2 demo,都移植过来,实现功能更强大的国标设备侧,这里主要是展示,收到国标平台侧的回传请求后,才打开摄像头,才开始编码打包,最大限度的减少资源的占用
266 3
|
文字识别 并行计算 PyTorch
MiniCPM-V 系列模型在多模态文档 RAG 中的应用(无需OCR的多模态文档检索+生成)
现在我们以 OpenBMB 基于 MiniCPM-V-2.0 训练的端到端多模态检索模型 MiniCPM-Visual-Embedding-v0 为例,实现无需OCR的多模态文档检索与问答。
MiniCPM-V 系列模型在多模态文档 RAG 中的应用(无需OCR的多模态文档检索+生成)
|
消息中间件 监控 Java
【Kafka节点存活大揭秘】如何让Kafka集群时刻保持“心跳”?探索Broker、Producer和Consumer的生死关头!
【8月更文挑战第24天】在分布式系统如Apache Kafka中,确保节点的健康运行至关重要。Kafka通过Broker、Producer及Consumer间的交互实现这一目标。文章介绍Kafka如何监测节点活性,包括心跳机制、会话超时与故障转移策略。示例Java代码展示了Producer如何通过定期发送心跳维持与Broker的连接。合理配置这些机制能有效保障Kafka集群的稳定与高效运行。
504 2
|
存储 数据可视化 PyTorch
Transformers 4.37 中文文档(十四)(1)
Transformers 4.37 中文文档(十四)
379 1
|
Java 应用服务中间件 数据库连接
【一文搞懂Servlet】
【一文搞懂Servlet】
|
存储 PyTorch TensorFlow
Transformers 4.37 中文文档(二)(2)
Transformers 4.37 中文文档(二)
510 7
|
机器学习/深度学习 计算机视觉
YOLOv10实战:SPPF原创自研 | SPPF_attention,重新设计加入注意力机制 | NEU-DET为案列进行展开
【7月更文挑战第1天】 优点:为了利用不同的池化核尺寸提取特征的方式可以获得更多的特征信息,提高网络的识别精度; 如何优化:在此基础上加入注意力机制,能够在不同尺度上更好的、更多的获取特征信息,从而获取全局视角信息并减轻不同尺度大小所带来的影响; SPPF_attention,重新设计加入注意力机制 ,在NEU-DEU任务中mAP50从0.683提升至0.703;
1339 3
|
并行计算
HuggingFace Tranformers 源码解析(1)
HuggingFace Tranformers 源码解析
246 0