动态代理
来源:互联网 发布:java工程师人才缺口 编辑:程序博客网 时间:2024/06/05 09:57
动态代理:
JDK5引入的动态代理机制,允许开发人员在运行时刻动态的创建代理类及其对象。在运行期间,可以动态的
创建出一个实现了多个接口的代理类。每个代理类的对象都会关联一个表示内部逻辑的InvocationHandler接口的实现。
当使用者调用了代理对象所代理的接口中的方法的时候,这个调用的信息会被传递到InvocationHandler的invoke方法
。在invoke方法的参数中可以获取到代理对象、方法对应的Method对象和调用的实际参数。invoke方法返回值被返回给
使用者。达到了对方法调用进行拦截的目的。
下面是一个禁止使用list接口中的add方法的例子
public List getList(final List list){
return (List)Proxy.newProxyInstance(DummyProxy.class.getClassLoader(),
new Class[]{List.clas},new InvocationHandler(){
public Object invoke(Object proxy, Method method, Object[]args)throws Throwable
{
if("add".equals(method.getName())){
throw new UnsupportedOperationException();
}else{
return method.invoke(list,args);
}
}
});
}
newProxyInstance源码方法签名:
public static Object newProxyInstance(ClassLoader loader,
Class<?>[] interfaces,
InvocationHandler h)
当代理对象的add方法被调用的时候,InvocationHandler中的invoke方法会被调用
当方法名称是add的时候抛出异常,如果不是add则执行原来的逻辑。
newProxyInstance参数分析:
其中ClassLoader主要用于加载反射对象的class和检查是否可代理(调用了checkProxyAccess(Reflection.getCallerClass(), loader, intfs),
final Class<?>[] intfs = interfaces.clone();可见此处intfs只是代理class的副本)
final InvocationHandler ih = h; //在判断代理的时候还调用过(isProxyClass())
返回return newInstance(cons, ih);//底层仍然是调用了cons(Constructor类型)的newInstance方法,
完成代理
JDK5引入的动态代理机制,允许开发人员在运行时刻动态的创建代理类及其对象。在运行期间,可以动态的
创建出一个实现了多个接口的代理类。每个代理类的对象都会关联一个表示内部逻辑的InvocationHandler接口的实现。
当使用者调用了代理对象所代理的接口中的方法的时候,这个调用的信息会被传递到InvocationHandler的invoke方法
。在invoke方法的参数中可以获取到代理对象、方法对应的Method对象和调用的实际参数。invoke方法返回值被返回给
使用者。达到了对方法调用进行拦截的目的。
下面是一个禁止使用list接口中的add方法的例子
public List getList(final List list){
return (List)Proxy.newProxyInstance(DummyProxy.class.getClassLoader(),
new Class[]{List.clas},new InvocationHandler(){
public Object invoke(Object proxy, Method method, Object[]args)throws Throwable
{
if("add".equals(method.getName())){
throw new UnsupportedOperationException();
}else{
return method.invoke(list,args);
}
}
});
}
newProxyInstance源码方法签名:
public static Object newProxyInstance(ClassLoader loader,
Class<?>[] interfaces,
InvocationHandler h)
当代理对象的add方法被调用的时候,InvocationHandler中的invoke方法会被调用
当方法名称是add的时候抛出异常,如果不是add则执行原来的逻辑。
newProxyInstance参数分析:
其中ClassLoader主要用于加载反射对象的class和检查是否可代理(调用了checkProxyAccess(Reflection.getCallerClass(), loader, intfs),
final Class<?>[] intfs = interfaces.clone();可见此处intfs只是代理class的副本)
final InvocationHandler ih = h; //在判断代理的时候还调用过(isProxyClass())
返回return newInstance(cons, ih);//底层仍然是调用了cons(Constructor类型)的newInstance方法,
完成代理
阅读全文
0 0
- 代理-->静态代理&动态代理
- 动态代理
- 动态代理
- 动态代理
- 动态代理
- 动态代理
- 动态代理
- 动态代理
- 动态代理
- 动态代理
- 动态代理
- 动态代理
- 动态代理
- 动态代理
- 动态代理
- 动态代理
- 动态代理
- 动态代理
- 中断下半部
- 简单快速幂
- solr 6.3 入门(五) facet.pivot的使用
- 暑假集训日记--8.21--树状数组
- 资源 | 数十种TensorFlow实现案例汇集:代码+笔记
- 动态代理
- 利用socket多线程访问服务器文件
- hpu 【1194】Judge
- Java 生成二维码
- Linux中写时复制的fork和vfork的实际区别
- c++题目
- 大家好
- 【线段问题创新思路】Hacker, pack your bags! CodeForces
- for循环输出菱形的形状【java】