设计模式12 - 代理模式

作者:billy
版权声明:著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处

代理模式

在代理模式(Proxy Pattern)中,一个类代表另一个类的功能。这种类型的设计模式属于结构型模式。
在代理模式中,我们创建具有现有对象的对象,以便向外界提供功能接口。

使用场景

  • 在访问一个类的时候做一些控制时。
  • 想要隐藏某个类时。
  • 一个类需要对不同的调用者提供不同的调用权限时。
  • 要扩展某个类的某个功能时。

优缺点

  • 优点:
    1、职责清晰。
    2、高扩展性。
    3、智能化。

  • 缺点:
    1、由于在客户端和真实主题之间增加了代理对象,因此有些类型的代理模式可能会造成请求的处理速度变慢。
    2、实现代理模式需要额外的工作,有些代理模式的实现非常复杂。

注意事项

1、和适配器模式的区别:适配器模式主要改变所考虑对象的接口,而代理模式不能改变所代理类的接口。
2、和装饰器模式的区别:装饰器模式为了增强功能,而代理模式是为了加以控制。

UML结构图

在这里插入图片描述

代码实现

interface.h
创建抽象类 - 图像; 创建具体类 -操作图像、代理图像
把真正需要操作的放到代理中完成

#include <string>
#include <iostream>
using namespace std;

class Image //基类-图像
{
public:
    Image() {}
    virtual ~Image() {}

    virtual void display() = 0;
};

class RealImage: public Image   //子类-操作图像
{
public:
    RealImage(string fileName): fileName(fileName)
    {
        loadFromDisk(fileName);
    }

    void loadFromDisk(string fileName) { cout << "Loading " + fileName << endl; }

    void display() { cout << "Displaying " + fileName << endl; }

private:
    string fileName;
};

class ProxyImage: public Image  //子类-代理图像
{
public:
    ProxyImage(string fileName): fileName(fileName)
    {
        realImage = nullptr;
    }

    void display()
    {
        if (realImage == nullptr)
        {
            realImage = new RealImage(fileName);
        }

        realImage->display();
    }

private:
    RealImage *realImage;
    string fileName;
};

main.cpp
实例应用 - 使用代理完成图像的加载,通过代理模式做到了逻辑和实现的彻底解耦

#include "interface.h"

int main()
{
    Image *image = new ProxyImage("xxx.jpg");
    image->display();

    return 0;
}

运行结果:
Loading xxx.jpg
Displaying xxx.jpg
  • 5
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值