动态代理
代理是一种常用的设计模式,其目的就是为其他对象提供一个代理以控制对某个对象的访问。代理类负责为委托类预处理消息,过滤消息并转发消息,以及进行消息被委托类执行后的后续处理。
为了保持行为的一致性,代理类和委托类通常会实现相同的接口,所以在访问者看来两者没有丝毫的区别。通过代理类这中间一层,能有效控制对委托类对象的直接访问,也可以很好地隐藏和保护委托类对象,同时也为实施不同控制策略预留了空间,从而在设计上获得了更大的灵活性。Java动态代理机制以巧妙的方式近乎完美地实践了代理模式的设计理念。
代理类可以分为两种。
静态代理:由程序员创建或特定工具自动生成源代码,再对其编译。程序运行之前就已经存在
动态代理:动态代理的字节码在程序运行时由java反射机制动态生成,无需程序员手工编写它的源代码。动态代理类不仅简化了简化了编程工作,而且提高了软件系统的可扩展性,因为Java反射机制可以生成任意类型的动态代理类。Java.lang.reflect包中的Proxy类和InvocationHandler接口提供了生成动态代理类的能力。
我们着重看一下动态代理:
Java动态代理类位于Java.lang.reflect包下,一般主要涉及到以下一个接口和一个类:
public interface InvocationHandler {
public Object invoke(Object proxy,Method method,Object[] args) throws Throwable;
}
参数说明:
Object proxy:指被代理的对象。
Method method:要调用的方法
Object[] args:方法调用时所需要的参数
Proxy类:
Proxy类是专门完成代理的操作类,可以通过此类为一个或多个接口动态地生成实现类,此类提供了如下的操作方法:
public static Object newProxyInstance(ClassLoader loader, Class<T>[] interfaces, InvocationHandler h)
throws IllegalArgumentException
参数说明:
ClassLoader loader:类加载器
Class<T>[] interfaces:得到全部的接口
InvocationHandler h:得到InvocationHandler接口的子类实例
Ps:类加载器
在Proxy类中的newProxyInstance()方法中需要一个ClassLoader类的实例,ClassLoader实际上对应的是类加载器,在Java中主要有一下三种类加载器;
Booststrap ClassLoader:此加载器采用C++编写,一般开发中是看不到的;
Extendsion ClassLoader:用来进行扩展类的加载,一般对应的是jre\lib\ext目录中的类;
AppClassLoader:(默认)加载classpath指定的类,是最常使用的是一种加载器。
代码示例:
动态代理代理类
package com.bjpowernode.drp.util; import java.lang.reflect.InvocationHandler; import java.lang.reflect.InvocationTargetException; import java.lang.reflect.Method; import java.lang.reflect.Proxy; import java.sql.Connection; /** * jdk动态代理代理类 * @author pc * */ public class TransactionHandler implements InvocationHandler { private Object targetObject; @Override /** * 调用方法 */ public Object invoke(Object proxy, Method method, Object[] args) throws Throwable { Object ret=null; try{ System.out.println(“方法调用之前进行的一些操作”); //调用目标对象的业务逻辑方法 ret=method.invoke(targetObject, args); System.out.println(“方法调用之后进行的一些操作”); Return ret; } public Object newProxyInstance(Object targetObject) { this.targetObject=targetObject; //取得委托对象 return Proxy.newProxyInstance(targetObject.getClass().getClassLoader(), targetObject.getClass().getInterfaces(), this); //返回代理对象 } }
接口类:
Public interface LogicManager{ //添加方法 public void addMethod(); }
实现类
Public class LogicImpl implements LogicManager{ public void addMethod(){ System.out.println(“添加方法…..”); } }
Test.java
public class Test{ public static void main(String[]args) { LogicManager lm=new LogicManager(); TransactionHandler transactionHandler=new TransactionHandler(); //对目标生成代理对象 lm =(FlowCardManager)transactionHandler.newProxyInstance(lm); lm. addMethod(); } }
参考博文:http://www.cnblogs.com/jqyp/archive/2010/08/20/1805041.html