栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > Java

详细分析java 动态代理

Java 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

详细分析java 动态代理

 1、动态代理的特点:

      字节码随用随创建,随用随加载

2、作用:

      不修改源码的基础上对源码进行加强

3、分类:

(1)基于接口的动态代理:

        涉及到的类:Proxy,由JDK官方提供,使用Proxy类中的newProxyInstance方法创建对象。创建代理对象时要求被代理对象至少实现一个接口,否则无法使用

              参数:

  • ClassLoader:类加载器,他是用于加载对象字节码的,和被代理对象使用相同的类加载器,为固定写法
  • class[]:字节码数组,他是用于让代理对象和被代理对象具有相同的方法,也是固定写法
  • InvocationHandler:用户提供增强的代码 ,他是让我们写如何代理。我们一般都是写一个该接口的实现类,通常情况下都是匿名内部类,但不是必须的,此接口的实现类都是谁用谁写

               示例: 创建 Producter接口和实体类

package com.mingqi.proxy;

public interface IProducer {
  
  public void SaleProduct(float money);

  
  public void AfterService(float money);
}
package com.mingqi.proxy;

public class Producer implements IProducer {
  public void SaleProduct(float money) {
    System.out.println("销售产品,并拿到钱:"+money);
  }

  public void AfterService(float money) {
    System.out.println("提供售后服务,并拿到钱:"+money);
  }
}

测试方法:

public static void main(String[] args) {
 
   final Producer producer=new Producer();
   IProdurcer proxyProducer= (IProdurcer)Proxy.newProxyInstance(producer.getClass().getClassLoader(), producer.getClass().getInterfaces(),
new InvocationHandler() {
  
  public Object invoke(Object proxy, Method method, Object[] args) throws Throwable {
    //提供增强的代码:
    Object returnValue=null;
    //1、获取方法执行的参数
    Float money=(Float) args[0];
    //判断当前方法是否是销售
    if("SaleProduct".equals(method.getName()))
    {
      returnValue=method.invoke(producer,money*0.8f);
    }
    return returnValue;
  }
});
    proxyProducer.SaleProduct(10000f);
  }

(2) 基于子类的动态代理

       涉及到的类:Enhancer,由第三方cglib提供,使用Enhancer类中的create方法创建对象。创建代理对象的类不能是最终类,否则无法使用

              参数:

  • Class:字节码,他是用于指定被代理对象的字节码,为固定写法
  • Callback:用户提供增强的代码 ,他是让我们写如何代理。我们一般都是写一个该接口的实现类,通常情况下都是匿名内部类,但不是必须的,此接口的实现类都是谁用谁写,我们一般写的都是该接口的子接口实现类MethodInterceptor

               示例: 创建 Product接口和实体类

package com.mingqi.cglib;


public class Product {

  
  public void saleProduct(float money){
    System.out.println("销售产品,并拿到钱:"+money);
  }

  
  public void afterService(float money){
    System.out.println("提供售后服务,并拿到钱:"+money);
  }
}

测试类及方法:

package com.mingqi.cglib;
import net.sf.cglib.proxy.Enhancer;
import net.sf.cglib.proxy.MethodInterceptor;
import net.sf.cglib.proxy.MethodProxy;
import java.lang.reflect.Method;
public class Client {
  public static void main(String[] args) {
    final Product product=new Product();
    Product cglibproduct= (Product) Enhancer.create(product.getClass(), new MethodInterceptor() {
      public Object intercept(Object o, Method method, Object[] objects, MethodProxy methodProxy) throws Throwable {
 Object returnValue=null;
 //1、获取方法执行的参数
 Float money=(Float)objects[0];
 //判断当前方法是不是销售
 if("SaleProduct".equals(method.getName())) {
   returnValue = method.invoke(product, money*0.8f);
 }
 return returnValue;
      }
    });
    cglibproduct.SaleProduct(1000f);
  }
}

以上就是创建动态代理对象的两种类型,以后要经常练习使用,让这种思想能给我们工作中带来方便。

到此这篇关于详细分析java 动态代理的文章就介绍到这了,更多相关java 动态代理内容请搜索考高分网以前的文章或继续浏览下面的相关文章希望大家以后多多支持考高分网!

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/133666.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号