设计模式(六)代理模式

——核心作用:通过代理,控制对对象的访问,可以详细控制访问某个(某类)对象的方法,在调用这个方法前做前置处理,从而实现将统一流程代码放到代理类中处理,调用这个方法后做后置处理。

——AOP(Aspect Oriented Programming面向切面编程)的核心实现机制

——核心角色:

  抽象角色:定义代理角色和真实角色的公共对外方法。

  真实角色:实现抽象角色,定义真实角色所要实现的业务逻辑,供代理角色调用。

       关注真正的业务逻辑。

  代理角色:实现抽象角色,是真实角色的代理,通过真实角色的业务逻辑方法来实现抽象方法,并可以附                      加自己的操作。

       将统一的流程控制放到代理角色中处理。

——应用场景:

  安全代理:屏蔽对真实角色的直接访问。

  远程代理:通过代理类处理进程方法调用(RMI)。

  延迟加载:先加载轻量级的代理对象,真正需要再加载真实对象。

    (比如你要开发一个大文档查看软件,大文档中有大的图片,有可能一个图片有100MB,在打开文件时不可能将所有的图片都显示出来,这样就可以使用代理模式,当需要查看图片时,用Proxy来进行大图片的打开)

——分类:

  静态代理(静态定义代理类)

  动态代理(动态生成代理类)

    • JDK自带的动态代理
    • Javaassist字节码操作库实现
    • CGLIB
    • ASM(底层使用指令,可维护性较差)


静态代理:

1. 定义一个Star接口

 1 package com.ztq.proxy.staticProxy;
 2
 3 public interface Star {
 4     /***
 5      * 面谈
 6      */
 7     void confer();
 8
 9     /***
10      * 签合同
11      */
12     void signContract();
13
14     /***
15      * 订票
16      */
17     void bookTicket();
18
19     /***
20      * 唱歌
21      */
22     void sing();
23
24     /***
25      * 收钱
26      */
27     void collectMoney();
28 }

2. 定义一个RealStar类

 1 package com.ztq.proxy.staticProxy;
 2
 3 public class RealStar implements Star{
 4
 5     @Override
 6     public void confer() {
 7         System.out.println("RealStar.confer()");
 8     }
 9
10     @Override
11     public void signContract() {
12         System.out.println("RealStar.signContract()");
13     }
14
15     @Override
16     public void bookTicket() {
17         System.out.println("RealStar.bookTicket()");
18     }
19
20     @Override
21     public void sing() {
22         System.out.println("RealStar.sing()");
23     }
24
25     @Override
26     public void collectMoney() {
27         System.out.println("RealStar.collectMoney()");
28     }
29
30 }

3. 定义一个ProxyStar类

 1 package com.ztq.proxy.staticProxy;
 2
 3 public class ProxyStar implements Star{
 4
 5     private Star star;
 6
 7     public ProxyStar(Star star){
 8         super();
 9         this.star = star;
10     }
11
12     @Override
13     public void confer() {
14         System.out.println("ProxyStar.confer()");
15     }
16
17     @Override
18     public void signContract() {
19         System.out.println("ProxyStar.signContract()");
20     }
21
22     @Override
23     public void bookTicket() {
24         System.out.println("ProxyStar.bookTicket()");
25     }
26
27     @Override
28     public void sing() {
29         star.sing();
30     }
31
32     @Override
33     public void collectMoney() {
34         System.out.println("ProxyStar.collectMoney()");
35     }
36
37 }

4. 定义一个客户端调用

 1 package com.ztq.proxy.staticProxy;
 2
 3 public class Client {
 4     public static void main(String[] args) {
 5         Star real = new RealStar();
 6         Star proxy = new ProxyStar(real);
 7
 8         proxy.confer();
 9         proxy.signContract();
10         proxy.bookTicket();
11         proxy.sing();
12         proxy.collectMoney();
13     }
14 }

运行结果:

ProxyStar.confer()
ProxyStar.signContract()
ProxyStar.bookTicket()
RealStar.sing()
ProxyStar.collectMoney()

UML图:



动态代理相比于静态代理的优点:抽象角色中(接口)声明的所有方法都被转移到调用处理器一个集中的方法中处理,这样我们可以更加灵活和统一的处理众多的方法。

JDK自带的动态代理:

  java.lang.reflect.Proxy 作用:动态生成代理类和对象

  java.lang.reflect.InvocationHandler(处理器接口)

    可以通过invoke方法实现对真实角色的代理访问。

    每次通过Proxy生成代理类对象时都要指定对应的处理器对象。

Star接口、RealStar类与静态代理一样,此处省略。

定义一个StarHandler类

 1 package com.ztq.proxy.dynamicProxy;
 2
 3 import java.lang.reflect.InvocationHandler;
 4 import java.lang.reflect.Method;
 5
 6 public class StarHandler implements InvocationHandler{
 7
 8     Star realStar;
 9
10     public StarHandler(Star realStar) {
11         super();
12         this.realStar = realStar;
13     }
14
15     @Override
16     public Object invoke(Object proxy, Method method, Object[] args)
17             throws Throwable {
18         Object object = null;
19         System.out.println("真正的方法执行前");
20         System.out.println("面谈,签合同,预付款,订机票");
21         if(method.getName().equals("sing")){
22             object = method.invoke(realStar, args);
23         }
24         System.out.println("真正的方法执行后");
25         System.out.println("收尾款");
26         return object;
27     }
28
29 }

定义一个客户端调用类

 1 package com.ztq.proxy.dynamicProxy;
 2
 3 import java.lang.reflect.Proxy;
 4
 5 public class Client {
 6     public static void main(String[] args) {
 7         Star realStar = new RealStar();
 8         StarHandler handler = new StarHandler(realStar);
 9         Star proxy = (Star)Proxy.newProxyInstance(ClassLoader.getSystemClassLoader(), new Class[]{Star.class}, handler);
10
11         proxy.bookTicket();
12         proxy.sing();
13     }
14 }

运行结果

真正的方法执行前
面谈,签合同,预付款,订机票
真正的方法执行后
收尾款
真正的方法执行前
面谈,签合同,预付款,订机票
RealStar.sing()
真正的方法执行后
收尾款
时间: 2024-12-08 16:08:02

设计模式(六)代理模式的相关文章

JAVA设计模式之代理模式

学编程吧JAVA设计模式之代理模式发布了,欢迎通过xuebiancheng8.com来访问 一.概述 给某一个对象提供一个代理,并由代理对象来完成对原对象的访问.代理模式是一种对象结构型模式. 二.适用场景 当无法直接访问某个对象或访问某个对象存在困难时可以通过一个代理对象来间接访问,为了保证客户端使用的透明性,委托对象与代理对象需要实现相同的接口. 三.UML类图 四.参与者 1.接口类:Subject 它声明了真实访问者和代理访问者的共同接口,客户端通常需要针对接口角色进行编程. 2.代理类

设计模式之代理模式20170724

结构型设计模式之代理模式: 一.含义 代理模式也叫做委托模式,其定义如下: 为其他对象提供一种代理以控制对这个对象的访问. 二.代码说明 1.主要有两个角色 1)具体主题角色 也叫做委托角色.被代理角色.它是业务逻辑的具体执行者. 2)代理主题角色 也叫做委托类.代理类.它负责对真实角色的应用,把所有抽象主题类定义的方法限制委托给真实主题角色实现,并且在真实主题角色处理完毕前后做预处理和善后处理工作. 一个代理类可以代理多个被委托者或被代理者. 2.在用C实现过程中也是参考这种思想,以游戏代理场

Android设计模式之代理模式 Proxy

一.概述 代理模式也是平时比较常用的设计模式之一,代理模式其实就是提供了一个新的对象,实现了对真实对象的操作,或成为真实对象的替身.在日常生活中也是很常见的.例如A要租房,为了省麻烦A会去找中介,中介会替代A去筛选房子,A坐享中介筛选的结果,并且交房租也是交给中介,这就是一个典型的日常生活中代理模式的应用.平时打开网页,最先开到的一般都是文字,而图片等一些大的资源都会延迟加载,这里也是使用了代理模式. 代理模式的组成: Abstract Subject:抽象主题-声明真实主题和代理主题共同的接口

【设计模式】代理模式

代理模式在所需对象和用户代码之间增加了一层对象,这个对象被称为代理.用户代码只需要直接操作代理对象即可.著名的代理模式的例子就是引用计数指针对象,它使得我们对真实对象的操作都需要经过引用计数指针对象.下面是用C++写的一个运用了代理模式的例子. #include <iostream> #include <string> using namespace std; // 作为接口的抽象基类 class Subject { public: virtual void DoAction()

设计模式之代理模式(Proxy)摘录

23种GOF设计模式一般分为三大类:创建型模式.结构型模式.行为模式. 创建型模式抽象了实例化过程,它们帮助一个系统独立于如何创建.组合和表示它的那些对象.一个类创建型模式使用继承改变被实例化的类,而一个对象创建型模式将实例化委托给另一个对象.创建型模式有两个不断出现的主旋律.第一,它们都将关于该系统使用哪些具体的类的信息封装起来.第二,它们隐藏了这些类的实例是如何被创建和放在一起的.整个系统关于这些对象所知道的是由抽象类所定义的接口.因此,创建型模式在什么被创建,谁创建它,它是怎样被创建的,以

【大话设计模式】——代理模式

对于面向对象的程序设计语言而言,继承和多态是两个最基本的概念.Hibernate 的继承映射可以理解持久化类之间的继承关系.例如:人和学生之间的关系.学生继承了人,可以认为学生是一个特殊的人,如果对人进行查询,学生的实例也将被得到. Hibernate支持三种继承映射策略: 使用 subclass 进行映射:将域模型中的每一个实体对象映射到一个独立的表中,也就是说不用在关系数据模型中考虑域模型中的继承关系和多态. 使用 joined-subclass 进行映射: 对于继承关系中的子类使用同一个表

设计模式之代理模式 c++实现以及详解

proxy模式 <1> 作用: 为其他对象提供一种代理以控制对这个对象的访问. <2> 代理模式的应用场景: 如果已有的方法在使用的时候需要对原有的方法进行改进,此时有两种办法: 1.修改原有的方法来适应.这样违反了"对扩展开放,对修改关闭"的原则. 2.就是采用一个代理类调用原有的方法,且对产生的结果进行控制.这种方法就是代理模式. 使用代理模式,可以将功能划分的更加清晰,有助于后期维护! <3> 结构图 代理类,含有一个指向RealSubject

JAVA设计模式(3)----代理模式

1.  什么是代理模式?Proxy Pattern 代理模式定义:为其他对象提供一种代理以控制对这个对象的访问.在某些情况下,一个对象不适合或者不能直接引用另一个对象,而代理对象可以在客户端和目标对象之间起到中介的作用. 通俗的讲,代理模式就是我很忙没空理你,你要想找我可以先找我的代理人,代理人和被代理人继承同一个接口.代理人虽然不能干活,但是被代理的人可以干活. 这个例子中有水浒传中的这么几个人:名垂青史的潘金莲,王婆,西门大官人.西门庆想要找潘金莲,需要找王婆做代理.首先定义一个接口:Kin

设计模式 11 —— 代理模式

设计模式目录: 设计模式 1 ——观察者模式 设计模式 2 —— 装饰者模式 设计模式 3 —— 迭代器和组合模式(迭代器) 设计模式 4 —— 迭代器和组合模式(组合) 设计模式 5 —— 工厂模式 设计模式 6 —— 单件模式 设计模式 7 —— 命令模式 设计模式 8 —— 适配器和外观模式 设计模式 9 —— 模板方法模式 设计模式 10 —— 状态模式 设计模式 11 —— 代理模式 概述 一 代理模式基本概念 二 参考 一 代理模式基本概念 代理模式为另一个对象提供一个替身或占位符以

跟我学设计模式视频教程——代理模式

课程视频 代理模式1 代理模式2 课程笔记 课程笔记 课程代码 课程代码 新课程火热报名中 课程介绍 跟我学设计模式视频教程--代理模式