zoukankan      html  css  js  c++  java
  • 设计模式之代理模式

    设计模式之代理模式

    在有些情况下,一个客户不能或者不想直接访问另一个对象,这时需要找一个中介帮忙完成某项任务,这个中介就是代理对象。例如,购买火车票不一定要去火车站买,可以通过 12306 网站或者去火车票代售点买。又如找女朋友、找保姆、找工作等都可以通过找中介完成。

    在软件设计中,使用代理模式的例子也很多,例如,要访问的远程对象比较大(如视频或大图像等),其下载要花很多时间。还有因为安全原因需要屏蔽客户端直接访问真实对象,如某单位的内部数据库等。

    代理模式的定义与特点

    代理模式的定义:由于某些原因需要给某对象提供一个代理以控制对该对象的访问。这时,访问对象不适合或者不能直接引用目标对象,代理对象作为访问对象和目标对象之间的中介。

    代理模式的主要优点有:
    • 代理模式在客户端与目标对象之间起到一个中介作用和保护目标对象的作用;
    • 代理对象可以扩展目标对象的功能;
    • 代理模式能将客户端与目标对象分离,在一定程度上降低了系统的耦合度,增加了程序的可扩展性

    其主要缺点是:
    • 代理模式会造成系统设计中类的数量增加
    • 在客户端和目标对象之间增加一个代理对象,会造成请求处理速度变慢;
    • 增加了系统的复杂度;

    那么如何解决以上提到的缺点呢?答案是可以使用动态代理方式

    代理模式的结构与实现

    代理模式的结构比较简单,主要是通过定义一个继承抽象主题的代理来包含真实主题,从而实现对真实主题的访问,下面来分析其基本结构和实现方法。

    1. 模式的结构

    代理模式的主要角色如下。
    1. 抽象主题(Subject)类:通过接口或抽象类声明真实主题和代理对象实现的业务方法。
    2. 真实主题(Real Subject)类:实现了抽象主题中的具体业务,是代理对象所代表的真实对象,是最终要引用的对象。
    3. 代理(Proxy)类:提供了与真实主题相同的接口,其内部含有对真实主题的引用,它可以访问、控制或扩展真实主题的功能。

    2.代码示例

     1 package proxy;
     2 public class ProxyTest {
     3     public static void main(String[] args) {
     4         Proxy proxy = new Proxy();
     5         proxy.Request();
     6     }
     7 }
     8 //抽象主题
     9 interface Subject {
    10     void Request();
    11 }
    12 //真实主题
    13 class RealSubject implements Subject {
    14     public void Request() {
    15         System.out.println("访问真实主题方法...");
    16     }
    17 }
    18 //代理
    19 class Proxy implements Subject {
    20     private RealSubject realSubject;
    21     public void Request() {
    22         if (realSubject == null) {
    23             realSubject = new RealSubject();
    24         }
    25         preRequest();
    26         realSubject.Request();
    27         postRequest();
    28     }
    29     public void preRequest() {
    30         System.out.println("访问真实主题之前的预处理。");
    31     }
    32     public void postRequest() {
    33         System.out.println("访问真实主题之后的后续处理。");
    34     }
    35 }
    View Code
  • 相关阅读:
    HDU 5213 分块 容斥
    HDU 2298 三分
    HDU 5144 三分
    HDU 5145 分块 莫队
    HDU 3938 并查集
    HDU 3926 并查集 图同构简单判断 STL
    POJ 2431 优先队列
    HDU 1811 拓扑排序 并查集
    HDU 2685 GCD推导
    HDU 4496 并查集 逆向思维
  • 原文地址:https://www.cnblogs.com/albertrui/p/15384487.html
Copyright © 2011-2022 走看看