zoukankan      html  css  js  c++  java
  • GoF23种设计模式之结构型模式之代理模式

    一、概述

            为其他对象提供一种代理以控制对这个对象的访问。

    二、适用性

    1.远程代理(RemoteProxy):为一个对象在不同的地址空间土工局部代表。

    2.虚代理(VirtualProxy):根据需要创建开销很大的对象。

    3.保护代理(ProtectionProxy):控制对原始对象的访问。

    4.智能代理(SmartReference):取代简单的指针,在访问对象时执行一些附加操作。

    三、参与者

    1.Proxy:保存一个引用使得代理可以访问实体。若RealSubject和Subject的接口相同,Proxy会引用Subject。提供一个与Subject的接口相同的接口,这样代理就可以用来替代实体。控制对实体的存取,并可能负责创建和删除它。其他功能依赖于代理的类型。

    2.Subject:定义RealSubject和Proxy的共用接口,这样就在任何使用RealSubject的地方都可以使用Proxy。

    3.RealSubject:定义Proxy所代表的实体。

    四、类图


    五、示例

    Proxy

    package cn.lynn.proxy;
    
    public class Intermediary implements IHouse {
        private IHouse house;
        
        public Intermediary() {
            System.out.println("这里是中介!");
            house = new User();
        }
    
        @Override
        public void buy() {
            System.out.println("中介开始服务...");
            house.buy();
            System.out.println("中介结束服务...");
        }
    
    }
    
    Subject
    package cn.lynn.proxy;
    
    public interface IHouse {
    
        public void buy();
    
    }
    
    RealSubject
    package cn.lynn.proxy;
    
    public class User implements IHouse {
    
        @Override
        public void buy() {
            System.out.println("客户买二手房!");
        }
    
    }
    
    Client
    package cn.lynn.proxy;
    
    public class Client {
    
        public static void main(String[] args) {
            IHouse house = new Intermediary();
            house.buy();
        }
    
    }
    
    Result
    这里是中介!
    中介开始服务...
    客户买二手房!
    中介结束服务...

  • 相关阅读:
    java中的“指针”
    UEditor1.4.3.3编辑器漏洞
    csrf攻击实例
    shiro java 反序列漏洞复现
    渗透面试问题
    了解 OWASP TOP 10
    网络基础知识回顾
    cs(cobalt strike)的使用
    解决docker-valhub漏洞环境下载慢的问题
    Vulhub漏洞CVE-2017-10271复现
  • 原文地址:https://www.cnblogs.com/innosight/p/3271147.html
Copyright © 2011-2022 走看看