JDK动态代理与CGLIB动态代理区别

本文深入探讨了CGLIB动态代理的实现原理与应用,通过具体的代码示例,展示了如何为未实现接口的类创建代理,以实现方法拦截与增强。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

JDK动态代理

  1. 只能代理实现了接口的类

  2. 没有实现接口的类不能实现JDK的动态代理

CGLIB动态代理

  1.  针对类来实现代理的

  2.  对指定目标类产生一个子类,通过方法拦击技术拦截所有父类方法的调用

 

使用Cglib实现动态代理


package com.imooc.cglib;
public class Train {
 public void move(){
  System.out.println("火车行驶中");
 }
}

import java.lang.reflect.Method;
import net.sf.cglib.proxy.Enhancer;
import net.sf.cglib.proxy.MethodInterceptor;
import net.sf.cglib.proxy.MethodProxy;
public class CglibProxy implements MethodInterceptor {
 
 private Enhancer enhancer = new Enhancer();
 
 public Object getProxy(Class clazz){
  //设置创建子类的类
  enhancer.setSuperclass(clazz);
  enhancer.setCallback(this);
  
  return enhancer.create();
 }
 
 /*
  * 拦截所有目标类方法的调用
  * obj:目标类的实例
  * m:目标方法的反射对象
  * args:方法的参数
  * proxy:代理类的实例
  * 
  * (non-Javadoc)
  * @see net.sf.cglib.proxy.MethodInterceptor#intercept(java.lang.Object, java.lang.reflect.Method, java.lang.Object[], net.sf.cglib.proxy.MethodProxy)
  */
 @Override
 public Object intercept(Object obj, Method m, Object[] args,
   MethodProxy proxy) throws Throwable {
  // TODO Auto-generated method stub
  
  System.out.println("日志开始");
  //代理类调用父类的方法
  proxy.invokeSuper(obj, args);
  System.out.println("日志结束");
  return null;
 }

package com.imooc.cglib;
public class Client {
 public static void main(String[] args) {
  CglibProxy proxy = new CglibProxy();
  Train t = (Train)proxy.getProxy(Train.class);
  t.move();
 }
}

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值