动态代理

 


 

程序的代理

要为已存在的多个具有相同接口的目标类的各个方法增加一些系统功能,例如,异常处理、日志、计算方法的运行时间、事务管理、等等

AOP                交叉业务: 有部分是相同的

交叉业务的编程问题即为面向方面的编程(Aspect oriented program ,简称AOP),AOP的目标就是要使交叉业务模块化。可以采用将切面代码移动到原始方法的周围,这与直接在方法中编写切面代码的运行效果是一样的

动态代理技术

要为系统中的各种接口的类增加代理功能,那将需要太多的代理类,全部采用静态代理方式,将是一件非常麻烦的事情!写成百上千个代理类,是不是太累!
JVM可以在运行期动态生成出类的字节码,这种动态生成的类往往被用作代理类,即动态代理类。
JVM生成的动态类必须实现一个或多个接口,所以,JVM生成的动态类只能用作具有相同接口的目标类的代理。
CGLIB库可以动态生成一个类的子类,一个类的子类也可以用作该类的代理,所以,如果要为一个没有实现接口的类生成动态代理类,那么可以使用CGLIB库。
代理类的各个方法中通常除了要调用目标的相应方法和对外返回目标返回的结果外,还可以在代理方法中的如下四个位置加上系统功能代码:
1.在调用目标方法之前
2.在调用目标方法之后
3.在调用目标方法前后
4.在处理目标方法异常的catch块中

创建动态类及查看其方法列表信息

 
 

import java.lang.reflect.Constructor;
import java.lang.reflect.Method;
import java.lang.reflect.Proxy;
import java.util.Collection;

public class ProxyTest {

 /**
  * @param args
  */
 public static void main(String[] args) {
  // TODO Auto-generated method stub
  Class clazzProxy = Proxy.getProxyClass(Collection.class.getClassLoader(), Collection.class);

//Proxy构造方法参数:类加载器, 必须有实现的接口
  String clazzName = clazzProxy.getName();
  System.out.println(clazzName);
  
  System.out.println("-------------begin constructors list ------------------");
  
  Constructor[] constructors = clazzProxy.getConstructors();//获得多个构造方法
  for(Constructor constructor : constructors){//遍历构造方法 按 ‘方法名(参数)’打印
   String name = constructor.getName();
   StringBuilder sBuilder = new StringBuilder(name);
   sBuilder.append("(");
   Class[] clazzParameters = constructor.getParameterTypes();//获得方法的多个参数类型
   for(Class clazzParameter : clazzParameters){
    sBuilder.append(clazzParameter.getName()).append(",");
   }
   if(clazzParameters != null && clazzParameters.length != 0)
    sBuilder.deleteCharAt(sBuilder.length()-1);//去掉最后面的“,”
   sBuilder.append(")");
   System.out.println(sBuilder.toString());
  }
  
System.out.println("-------------begin methods list ------------------");
  
  Method[] methods = clazzProxy.getMethods();
  for(Method method : methods){
   String name = method.getName();
   StringBuilder sBuilder = new StringBuilder(name);
   sBuilder.append("(");
   Class[] clazzParameters = method.getParameterTypes();
   for(Class clazzParameter : clazzParameters){
    sBuilder.append(clazzParameter.getName()).append(",");
   }
   if(clazzParameters != null && clazzParameters.length != 0)
    sBuilder.deleteCharAt(sBuilder.length()-1);
   sBuilder.append(")");
   System.out.println(sBuilder.toString());
  }

System.out.println("-------------begin create instance object ------------------");
  
  Constructor construct = clazzProxy.getConstructor(InvocationHandler.class);
  class MyInvocationhandler implements InvocationHandler{//实现Invocationhandler接口

   @Override
   public Object invoke(Object proxy, Method method, Object[] args)
     throws Throwable {

    return null;
   }
   
  }
  Collection proxy1 = (Collection)construct.newInstance(new MyInvocationhandler());

  System.out.println(proxy1);
  
  
  Collection proxy2 = (Collection)construct.newInstance(new InvocationHandler() {
   
   @Override
   public Object invoke(Object proxy, Method method, Object[] args)
     throws Throwable {
    return null;
   }
  });//用匿名内部类作参数
  
  Collection proxy3 = (Collection)Proxy.newProxyInstance(
    Collection.class.getClassLoader(),
    new Class[]{Collection.class},
    new InvocationHandler() {
     ArrayList target = new ArrayList();//这是目标类,应提取
     @Override
     public Object invoke(Object proxy, Method method, Object[] args)
       throws Throwable {
      long startTime = System.currentTimeMillis();//系统的功能也应提取
      Object retVal = method.invoke(target, args);//运行传进来的方法,对象是目标类对象
      long endTime = System.currentTimeMillis();
      System.out.println(proxy.getClass().getName()+"...time.."+(endTime-startTime));
      return retVal;
     }
    }
    );
  proxy3.add("abc");

//其实代理类内部有一个成员变量是Invocationhandler ,所以构造方法传的参数是Invocationhandler类型

//proxy3.add("abc")其实就是调用invoke方法,invoke方法的参数是proxy3 add()的Method类 "abc"

//就是在应运行的方法上加入其他功能,目标类的方法是必须运行的(目标类是不确定的),所以可以将目标类和添加的功能提取

private static Object getProxy(final Object target) {//参数传入目标类 ,返回代理类

  Object proxy3 = Proxy.newProxyInstance(
    target.getClass().getClassLoader(),
    target.getClass().getInterfaces(),
    new InvocationHandler() {
     
     @Override
     public Object invoke(Object proxy, Method method, Object[] args)
       throws Throwable {
      long startTime = System.currentTimeMillis();
      Object retVal = method.invoke(target, args);
      long endTime = System.currentTimeMillis();
      System.out.println(proxy.getClass().getName()+"...time.."+(endTime-startTime));
      return retVal;
     }
    }
    );
  return proxy3;
 }

 }

}

-------------------------------------------------------------------------------------------------------

import java.lang.reflect.Method;

public interface Advice {//将系统功能方法提取

 public void beforeMethod(Method method);
 public void afterMethod(Method method);
}

 

import java.lang.reflect.Method;

public class MyAdvice implements Advice {
 
 long startTime;
 public void beforeMethod(Method method) {
  
  startTime = System.currentTimeMillis();
 }

 public void afterMethod(Method method){
  
  long endTime = System.currentTimeMillis();
  System.out.println(method.getName()+"...time.."+(endTime-startTime));
 }

}

 

private static Object getProxy(final Object target,final Advice advice) {//该方法可以相当于一个模板

  Object proxy3 = Proxy.newProxyInstance(
    target.getClass().getClassLoader(),
    target.getClass().getInterfaces(),
    new InvocationHandler() {
     
     @Override
     public Object invoke(Object proxy, Method method, Object[] args)
       throws Throwable {
      advice.beforeMethod(method);
      Object retVal = method.invoke(target, args);
      advice.afterMethod(method);
      return retVal;
     }
    }
    );
  return proxy3;
 }


内容概要:《2024年中国城市低空经济发展指数报告》由36氪研究院发布,指出低空经济作为新质生产力的代表,已成为中国经济新的增长点。报告从发展环境、资金投入、创新能力、基础支撑和发展成效五个维度构建了综合指数评价体系,评估了全国重点城市的低空经济发展状况。北京和深圳在总指数中名列前茅,分别以91.26和84.53的得分领先,展现出强大的资金投入、创新能力和基础支撑。低空经济主要涉及无人机、eVTOL(电动垂直起降飞行器)和直升机等产品,广泛应用于农业、物流、交通、应急救援等领域。政策支持、市场需求和技术进步共同推动了低空经济的快速发展,预计到2026年市场规模将突破万亿元。 适用人群:对低空经济发展感兴趣的政策制定者、投资者、企业和研究人员。 使用场景及目标:①了解低空经济的定义、分类和发展驱动力;②掌握低空经济的主要应用场景和市场规模预测;③评估各城市在低空经济发展中的表现和潜力;④为政策制定、投资决策和企业发展提供参考依据。 其他说明:报告强调了政策监管、产业生态建设和区域融合错位的重要性,提出了加强法律法规建设、人才储备和基础设施建设等建议。低空经济正加速向网络化、智能化、规模化和集聚化方向发展,各地应找准自身比较优势,实现差异化发展。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值