代理模式是常用的Java 设计模式,它的特征是
代理类与委托类有同样的接口。
代理类主要负责为委托类预处理消息、过滤消息、把消息转发给委托类,以及事后处理消息等。代理类与委托类之间通常会存在关联关系,一个代理类的对象与一个委托类的对象关联,代理类的对象本身并不真正实现服务,而是通过调用委托类的对象的相关方法,来提供特定的服务。按照代理类的创建时期,代理类可分为两种。
静态代理类:由程序员创建或由特定工具自动生成源代码,再对其编译。在程序运行前,代理类的.class文件就已经存在了。
动态代理类:在程序运行时,运用反射机制动态创建而成。
本文是一个静态代理的例子
例子中HelloServiceProxy 类(如例程10-13所示)是代理类,HelloServiceImpl
类(如例程10-12所示)是委托类,这两个类都实现了HelloService接口(如例程10-11
所示)。其中HelloServiceImpl类是HelloService接口的真正实现者,HelloServiceProxy类是通过调用HelloServiceImpl 类的相关方法来提供特定服务的。HelloServiceProxy类的echo()方法和getTime()方法会分别调用被代理的HelloServiceImpl 对象的echo()方法和getTime()方法,并且在方法调用前后都会执行一些简单的打印操作。由此可见,代理类可以为委托类预处理消息、把消息转发给委托类和事后处理消息等。
例程10-11 HelloService.java
package proxy;
import java.util.Date;
public interface HelloService{//服务接口
public String echo(String msg);
public Date getTime();
}
例程10-12 HelloServiceImpl.java
package proxy;
import java.util.Date;
public class HelloServiceImpl implements HelloService{//委托类
public String echo(String msg){
return "echo:"+msg;
}
public Date getTime(){
return new Date();
}
}
例程10-13 HelloServiceProxy.java
package reflection.proxy.Static;
import java.util.Date;
public class HelloServiceProxy implements IHelloService { //代理类
private IHelloService helloService; // 表示被代理的HelloService 实例
public HelloServiceProxy(IHelloService helloService) {
this.helloService = helloService;
}
public void setHelloServiceProxy(IHelloService helloService) {
this.helloService = helloService;
}
public String echo(String msg) {
System.out.println("before calling echo()"); // 预处理
String result = helloService.echo(msg); // 调用被代理的HelloService
// 实例的echo()方法
System.out.println("after calling echo()"); // 事后处理
return result;
}
public Date getTime() {
System.out.println("before calling getTime()"); // 预处理
Date date = helloService.getTime(); // 调用被代理的HelloService 实例的getTime()方法
System.out.println("after calling getTime()"); // 事后处理
return date;
}
}
在Client1 类(如例程10-14 所示)的main()方法中,先创建了一个HelloServiceImpl
对象,又创建了一个HelloServiceProxy对象,最后调用HelloServiceProxy对象的echo()方法。
例程10-14 Client1.java
package reflection.proxy.Static;
public class Client1 {
public static void main(String args[]) {
IHelloService helloService = new HelloServiceImpl();
IHelloService helloServiceProxy = new HelloServiceProxy(helloService);
System.out.println(helloServiceProxy.echo("hello"));
}
}
运行Client1 结果:
before calling echo()
after calling echo()
echo:hello
说明:HelloServiceProxy 类的源代码是由程序员编写的,在程序运行前,它的.class文件就已经存在了,这种代理类称为静态代理类。
动态代理---------见java 反射机制(四)动态代理
分享到:
相关推荐
反射实例-JAVA反射机制.doc反射实例-JAVA反射机制.doc反射实例-JAVA反射机制.doc反射实例-JAVA反射机制.doc反射实例-JAVA反射机制.doc反射实例-JAVA反射机制.doc反射实例-JAVA反射机制.doc反射实例-JAVA反射机制.doc...
面试经典题型,很值得分享的。 我们面试经常会遇到的问题。
java 的试题-------------------------
JAVA反射机制-Class类-Class对象的获取.pdf
java反射机制和动态代理的原理,熟悉反射机制和动态代理
java反射机制与动态代理 java反射机制 java反射机制java反射机制java反射机制java反射机制
熟悉反射机制很好地帮助理解j2ee框架 十分好的视频资料
Java 反射机制、Java 的类反射机制、Java 反射机制的学习、Java 反射Reflection--运行时生成实例 java反射机制的手册文档
3.2.1 Java反射机制的概念 3.2.2 反射机制的功能 3.2.3 Java反射机制的相关API 3.2.4 使用反射机制的步骤 3.2.5 反射机制的应用场景 3.2.6 反射机制的优缺点 Java高级程序设计实战教程第三章-Java反射机制全文共15页...
Chp15 反射Key Point ●Class 对象及其基本操作●Method 对象以及invoke 方法●标注练习 1. (类对象)要获得类对象,有三种不同的方式,分别为_____________________、___________________、_____________________...
精华java-反射机制-reflection-完整例子-具体说明-工程实际(完整版).doc
深入了解java反射机制的原理,通过反射机制可以破坏单例模式,如何防止通过反射机制拿到单例模式的构造器呢?用枚举类可破
Java中的代理模式--静态代理和动态代理 Java中的代理模式--静态代理和动态代理
JAVA设计模式--程序设计--反射--注解--泛型
JAVA的反射机制与动态代理
Java反射机制,比较简洁但是还是挺有用的,较全面PPT
java反射机制及动态代理的ppt java反射机制及动态代理的ppt
Java 第三阶段增强分析需求,代码实现能力【反射】---- 代码 Java 第三阶段增强分析需求,代码实现能力【反射】---- 代码 Java 第三阶段增强分析需求,代码实现能力【反射】---- 代码 Java 第三阶段增强分析需求,...
一个例子8个demo让你了解Java反射机制