设计模式- 代理模式(Proxy Pattern)结构|原理|优缺点|场景|示例

这篇具有很好参考价值的文章主要介绍了设计模式- 代理模式(Proxy Pattern)结构|原理|优缺点|场景|示例。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

                                    设计模式(分类)        设计模式(六大原则)   

    创建型(5种)        工厂方法         抽象工厂模式        单例模式        建造者模式        原型模式

    结构型(7种)        适配器模式        装饰器模式        代理模式        ​​​​​​外观模式      桥接模式        组合模式       享元模式

    行为型(11种)       策略模式        模板方法模式        观察者模式        迭代器模式        责任链模式        命令模式

                                   备忘录模式          状态模式          访问者模式        中介者模式    


代理模式(Proxy Pattern)是一种结构型设计模式,它为其他对象(被代理对象)提供一个代理对象,并由代理对象控制对被代理对象的访问。代理模式通过引入代理对象来间接访问目标对象,从而实现对目标对象的增强、控制访问权限、远程访问等功能。代理模式的关键在于代理类与目标类具有相同的接口,客户端可以透明地使用代理对象代替目标对象。

模式结构

代理模式通常包含以下角色:

  1. 抽象主题(Subject):定义了目标对象和代理对象共有的接口,这样在任何使用目标对象的地方都可以使用代理对象。

  2. 真实主题(Real Subject):也称为被代理对象,实现了抽象主题接口,包含具体业务逻辑。

  3. 代理(Proxy):也实现了抽象主题接口,其内部持有真实主题的引用。代理对象在实现接口方法时,可以选择调用真实主题的方法,也可以在调用前后添加额外的操作,如预处理、后处理、访问控制、日志记录等。

工作原理

  • 客户端:通过代理对象来调用目标对象的方法,对客户端而言,代理对象与真实主题对象在接口上是透明的,客户端无需关心具体使用的是哪个对象。
  • 代理:实现了与真实主题相同的接口,内部持有真实主题的引用。代理对象在接收到客户端请求时,可以选择直接调用真实主题的方法,也可以在调用前后添加额外的操作。
  • 真实主题:实现了抽象主题接口,包含具体的业务逻辑。在代理模式中,真实主题通常不直接暴露给客户端,而是通过代理对象间接访问。

代理模式的分类

  1. 静态代理:代理类在编译时就确定,由程序员创建代理类或使用工具生成。静态代理的优点是直观、简单,缺点是需要为每个具体主题都创建一个对应的代理类,增加了代码量和维护成本。

  2. 动态代理:代理类在运行时动态生成,如Java中的JDK动态代理和CGLIB库。动态代理的优点是可以减少代码量,只需要编写一个通用的代理类生成器,适用于需要为大量类生成代理的情况。

优缺点

优点
  • 职责清晰:代理对象与真实主题对象职责明确,代理对象负责控制访问、增强功能等,真实主题对象专注于业务逻辑。
  • 扩展性好:通过代理模式可以方便地添加新的功能,如访问控制、日志记录等,而无需修改真实主题。
  • 保护真实主题:通过代理对象可以隐藏真实主题的实现细节,提供额外的安全性和控制。
缺点
  • 增加复杂性:引入代理对象会使系统变得更复杂,增加了额外的类和对象关系。
  • 性能损耗:代理模式可能会带来一定的性能损耗,尤其是在代理对象执行额外操作的情况下。

适用场景

  • 需要为对象增加额外功能:如添加日志、事务管理、访问控制等,而又不想修改对象本身。
  • 需要对对象的访问进行控制:如远程访问、延迟加载、资源优化等。
  • 需要隐藏对象的复杂性:通过代理对象对外提供简洁的接口,隐藏真实主题的复杂实现。

代码示例(以Java为例,展示静态代理)

// 抽象主题(接口)
interface Image {
    void display();
}

// 真实主题(被代理对象)
class RealImage implements Image {
    private String fileName;

    public RealImage(String fileName) {
        this.fileName = fileName;
        loadFromDisk(fileName);
    }

    private void loadFromDisk(String fileName) {
        System.out.println("Loading image from disk: " + fileName);
    }

    @Override
    public void display() {
        System.out.println("Displaying image: " + fileName);
    }
}

// 代理
class ProxyImage implements Image {
    private RealImage realImage;
    private String fileName;

    public ProxyImage(String fileName) {
        this.fileName = fileName;
    }

    @Override
    public void display() {
        if (realImage == null) {
            realImage = new RealImage(fileName);
        }
        realImage.display();
    }
}

// 客户端代码
public class Client {
    public static void main(String[] args) {
        Image proxyImage = new ProxyImage("large-image.jpg");
        proxyImage.display();  // 输出:Loading image from disk: large-image.jpg, Displaying image: large-image.jpg

        System.out.println("\nDisplaying image again:");
        proxyImage.display();  // 输出:Displaying image: large-image.jpg
    }
}

在这个Java示例中:

  • Image接口作为抽象主题,定义了显示图像的方法。
  • RealImage类是需要被代理的真实主题,实现了Image接口,包含了从磁盘加载图像和显示图像的业务逻辑。
  • ProxyImage类作为代理,实现了Image接口,内部持有RealImage对象的引用。ProxyImage在实现display()方法时,首先检查RealImage对象是否已经加载,如果没有则先加载图像,然后调用RealImagedisplay()方法显示图像。这样实现了延迟加载的功能,只有在真正需要显示图像时才从磁盘加载,提高了性能。

客户端代码创建ProxyImage对象,并通过代理对象调用display()方法,实现了对真实主题对象的延迟加载。客户端无需关心代理对象的实现细节,只需面向Image接口编程。文章来源地址https://www.toymoban.com/news/detail-856843.html

 代码示例(以Python为例)

# 抽象主题(接口)
class Image:
    def display(self):
        raise NotImplementedError("Subclasses must implement this method")

# 真实主题(被代理对象)
class RealImage(Image):
    def __init__(self, filename):
        self.filename = filename
        self.load_from_disk()

    def load_from_disk(self):
        print(f"Loading image from disk: {self.filename}")

    def display(self):
        print(f"Displaying image: {self.filename}")

# 代理
class ProxyImage(Image):
    def __init__(self, filename):
        self.filename = filename
        self.real_image = None

    def display(self):
        if not self.real_image:
            self.real_image = RealImage(self.filename)
        self.real_image.display()

# 客户端代码
def main():
    proxy_image = ProxyImage("large-image.jpg")
    proxy_image.display()  # 输出:Loading image from disk: large-image.jpg, Displaying image: large-image.jpg

    print("\nDisplaying image again:")
    proxy_image.display()  # 输出:Displaying image: large-image.jpg

if __name__ == "__main__":
    main()

在这个Python示例中:

  • Image类作为抽象主题,定义了显示图像的display()方法。
  • RealImage类是需要被代理的真实主题,继承自Image类,包含了从磁盘加载图像和显示图像的业务逻辑。
  • ProxyImage类作为代理,同样继承自Image类,内部持有RealImage对象的引用。ProxyImage在实现display()方法时,首先检查RealImage对象是否已经加载,如果没有则先加载图像,然后调用RealImagedisplay()方法显示图像。这样实现了延迟加载的功能,只有在真正需要显示图像时才从磁盘加载,提高了性能。

客户端代码创建ProxyImage对象,并通过代理对象调用display()方法,实现了对真实主题对象的延迟加载。客户端无需关心代理对象的实现细节,只需面向Image接口编程。

到了这里,关于设计模式- 代理模式(Proxy Pattern)结构|原理|优缺点|场景|示例的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 设计模式-抽象工厂模式(Abstract Factory Pattern)结构|原理|优缺点|场景|示例

     目录         设计模式(分类)        设计模式(六大原则)        创建型         工厂方法         抽象工厂模式        单例模式        建造者模式        原型模式      结构型         适配器模式        装饰器模式      

    2024年04月22日
    浏览(32)
  • (二)结构型模式:8、代理模式(Proxy Pattern)(C++示例)

    目录 1、代理模式(Proxy Pattern)含义 2、代理模式的UML图学习 3、代理模式的应用场景  4、代理模式的优缺点 5、C++实现代理模式的实例 1、代理模式(Proxy Pattern)含义 代理模式(Proxy),为其他对象提供一种代理以控制对这个对象的访问。 代理模式(Proxy Pattern)是一种结构

    2024年02月12日
    浏览(29)
  • 设计模式-代理模式Proxy

    代理设计模式(Proxy Design Pattern)是一种结构型设计模式,它为其他对象 提供一个代理,以控制对这个对象的访问 。代理模式可以用于实现懒加载、安全访问控制、日志记录等功能。 在设计模式中,代理模式可以分为 静态代理和动态代理 。静态代理是指 代理类在编译时 就

    2024年02月10日
    浏览(31)
  • 设计模式之代理模式(Proxy)

    当我们需要使用的对象很复杂或者需要很长时间去构造,这时就可以使用代理模式(Proxy)。例如:如果构建一个对象很耗费时间和计算机资源,代理模式(Proxy)允许我们控制这种情况,直到我们需要使用实际的对象。一个代理(Proxy)通常包含和将要使用的对象同样的方法,一旦开

    2024年02月12日
    浏览(34)
  • 设计模式之代理模式(Proxy)的C++实现

    在组件的开发过程中,有些对象由于某种原因(比如对象创建的开销很大,或者对象的一些操作需要做安全控制,或者需要进程外的访问等),会使Client使用者在操作这类对象时可能会存在问题:(1)使用者直接访问这种对象会使系统带来很多麻烦。(2)或者使用者使不能

    2024年02月12日
    浏览(30)
  • 设计模式——1_6 代理(Proxy)

    诗有可解不可解,若镜花水月勿泥其迹可也 —— 谢榛 为其他对象提供一种代理以控制对这个对象的访问 某天,你突发奇想,想做一个可以展示指定文件夹内所有图片的桌面应用。这个应用很简单,遍历文件夹,发现图片文件,把图片加载到GUI上的图片列表里,显示图片名和

    2024年01月25日
    浏览(33)
  • 设计模式之代理模式(Proxy),以C++为例,实现远程代理、虚拟代理、保护代理等。

            兄弟姐妹们好,又是好久没有更新了,今天给大家简单介绍代理模式,一个很简单的设计模式,旨在不改变原对象的情况下通过代理对象来控制对原对象的访问。代理模式根据具体情况还可以分为远程代理、虚拟代理、保护代理等,下面来介绍一下。 目录  一、代理

    2023年04月09日
    浏览(29)
  • 代理模式【Proxy Pattern】

    什么是代理模式呢?我很忙,忙的没空理你,那你要找我呢就先找我的代理人吧,那代理人总要知道 被代理人能做哪些事情不能做哪些事情吧,那就是两个人具备同一个接口,代理人虽然不能干活,但是被 代理的人能干活呀。 举例子: 比如西门庆找潘金莲,那潘金莲不好意

    2024年02月12日
    浏览(27)
  • 结构型设计模式之代理模式【设计模式系列】

    C++技能系列 Linux通信架构系列 C++高性能优化编程系列 深入理解软件架构设计系列 高级C++并发线程编程 设计模式系列 期待你的关注哦!!! 现在的一切都是为将来的梦想编织翅膀,让梦想在现实中展翅高飞。 Now everything is for the future of dream weaving wings, let the dream fly in reali

    2024年02月16日
    浏览(35)
  • 设计模式—结构型模式之代理模式

    代理模式(Proxy Pattern) ,给某一个对象提供一个代理,并由代理对象控制对原对象的引用,对象结构型模式。 比如我们有一个直播平台,提供了直播功能,但是如果不进行美颜,可能就比较冷清。所以美颜功能就是我们的增强,可以用静态代理来实现。 直播接口: 直播类: 如果

    2024年02月05日
    浏览(46)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包