动态代理

来源:互联网 发布:linux 查看ip访问限制 编辑:程序博客网 时间:2024/04/30 10:03
 

         代理是一种常用的设计模式,其目的就是为其他对象提供一个代理以控制对某个对象的访问。代理类负责为委托类预处理消息,过滤消息并转发消息,以及进行消息被委托类执行后的后续处理。

        为了保持行为的一致性,代理类和委托类通常会实现相同的接口,所以在访问者看来两者没有丝毫的区别。通过代理类这中间一层,能有效控制对委托类对象的直接访问,也可以很好地隐藏和保护委托类对象,同时也为实施不同控制策略预留了空间,从而在设计上获得了更大的灵活性。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

原创粉丝点击