动态代理
来源:互联网 发布: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
- 代理-->静态代理&动态代理
- 动态代理
- 动态代理
- 动态代理
- 动态代理
- 动态代理
- 动态代理
- 动态代理
- 动态代理
- 动态代理
- 动态代理
- 动态代理
- 动态代理
- 动态代理
- 动态代理
- 动态代理
- 动态代理
- 动态代理
- Javascript学习笔录9(窗口属性操作-status、背景色、title等)
- vi 常用命令行
- ajax异步上传输图片
- [VSTS] 配置 Team Foundation Server 团队权限最佳实践
- javascript操作table(insertRow(),deleteRow(),insertCell(),deleteCel...
- 动态代理
- 学习视频网站
- TCP/IP详解学习笔记(4)-ICMP协议,ping和Traceroute
- 持续集成过程中,临时文件太多导致编译不通过问题的解决方案
- malloc()函数(Linux程序员手册)及函数的正确使用
- Linux内存管理之页面回收
- VS11 Beta 安装体验
- IE6正常显示PNG-24图片
- 工控方案 ( W5100/5300+任何MCU )