CGLIB 和 JDK生成动态代理类的区别

来源:互联网 发布:zookeeper 默认端口 编辑:程序博客网 时间:2024/06/08 02:52
AOP 使用的设计模式就是代理模式,是对IOC设计的补充。为了扩展性,往往会加上反射,动态生成字节码,生成代理类。 
这里往往还会使用到DI,把代理的实现类通过依赖注入的方式,传给代理工厂。 
关于生成动态代理类的方式有两种:JDK和CGLIB。 
CGLIB,是一个开源工具。spring 和hibernate已经广泛使用。 

JDK动态代理和CGLIB字节码生成的区别? 
JDK动态代理只能对实现了接口的类生成代理,而不能针对类 
CGLIB是针对类实现代理,主要是对指定的类生成一个子类,覆盖其中的方法 

因为是继承,所以该类或方法最好不要声明成final 


import net.sf.cglib.proxy.Enhancer;  

import net.sf.cglib.proxy.MethodInterceptor;  

import net.sf.cglib.proxy.MethodProxy;  

实现接口:MethodInterceptor

回调方法:intercept

CGLIB:


[java] view plaincopy在CODE上查看代码片派生到我的代码片
  1. public Object createProxyObject(Object obj) {  
  2.         this.targetObject = obj;  
  3.         Enhancer enhancer = new Enhancer();  
  4.         enhancer.setSuperclass(obj.getClass());  
  5.         enhancer.setCallback(this);  
  6.         Object proxyObj = enhancer.create();  
  7.         return proxyObj;// 返回代理对象,返回的对象其实就是一个封装了“实现类”的代理类,是实现类的实例。  
  8.     }  

import java.lang.reflect.InvocationHandler;
import java.lang.reflect.Method;
import java.lang.reflect.Proxy;

实现接口:InvocationHandler

回调方法:invoke

JDK: 

[java] view plaincopy在CODE上查看代码片派生到我的代码片
  1. public Object newProxy(Object targetObject) {// 将目标对象传入进行代理  
  2.         this.targetObject = targetObject;  
  3.         return Proxy.newProxyInstance(targetObject.getClass().getClassLoader(),  
  4.                 targetObject.getClass().getInterfaces(), this);// 返回代理对象  
  5.     }  

看上面的代码。在动太生成代理类时,传递的是实现类所所实现的接口argetObject.getClass().getInterfaces()。JDK只能对于接口进行做代理。如果换成类的话,则会抛java.lang.ClassCastException异常。

0 0
原创粉丝点击