「java多级代理」代理Java

博主:adminadmin 2022-11-28 09:24:07 49

本篇文章给大家谈谈java多级代理,以及代理Java对应的知识点,希望对各位有所帮助,不要忘了收藏本站喔。

本文目录一览:

Java怎么实现多层动态代理

java动态代理主要是通过Proxy类的newProxyInstance()方法,该方法需要三个参(ClassLoader loader, Class?[] interfaces, InvocationHandler h),其中分别为:

①:该对象的类加载器classloader

②:被代理类的类对象

③:一个InvocationHandler 处理器接口

InvocationHandler中有一个方法:invoke(Object proxy, Method method, Object[] args) ,通过显式调用可以实现对代理对象的类方法进行操作,这里主要是采用反射的原理,SrpingAop就是利用这一点进行实现的。

java中的代理是什么意思?

代理模式在设计模式中的定义就是:为其他对象提供一种代理以控制对这个对象的访问。说白了就是,在一些情况下客户不想或者不能直接引用一个对象,而代理对象可以在客户和目标对象之间起到中介作用,去掉客户不能看到的内容和服务或者增添客户需要的额外服务。

Java代理的三种模式有什么?

Java的三种代理模式简述

本文着重讲述三种代理模式在java代码中如何写出,为保证文章的针对性,暂且不讨论底层实现原理,具体的原理将在下一篇文章中讲述。

代理模式是什么

代理模式是一种设计模式,简单说即是在不改变源码的情况下,实现对目标对象的功能扩展。

比如有个歌手对象叫Singer,这个对象有一个唱歌方法叫sing()。

假如你希望,通过你的某种方式生产出来的歌手对象,在唱歌前后还要想观众问好和答谢,也即对目标对象Singer的sing方法进行功能扩展。

但是往往你又不能直接对源代码进行修改,可能是你希望原来的对象还保持原来的样子,又或许你提供的只是一个可插拔的插件,甚至你有可能都不知道你要对哪个目标对象进行扩展。这时就需要用到java的代理模式了。网上好多用生活中的经理人的例子来解释“代理”,看似通俗易懂,但我觉得不适合程序员去理解。程序员应该从代码的本质入手。

Java 几种动态代理实现及其性能比较

1. 动态代理是指在运行时,动态生成代理类。代理类的字节码将在运行时生成并载入当前的ClassLoader.

生成动态代理类的方法很多,如JDK自带的动态代理、CGLIB、Javassist或者ASM库。

JDK动态代理使用简单,它内置在JDK中,因此不需要引入第三方Jar包,但相对功能比较弱。CGLIB和Javassist都是高级的字节码生成库,总体性能比JDK自带的动态代理好,而且功能十分强大。ASM是低级的字节码生成工具,使用ASM已经近乎在于使用Javabytecode编程,对开发人员要求较高,也是性能最好的一种动态代理生辰工具。但ASM的使用是在过于繁琐,而且性能也没有数量级的提升,与CGLIB等高级字节码生成工具相比,ASM程序的可维护性也较差。

JDK实现

1、步骤

1)通过实现InvocationHandler接口创建自己的调用处理器

2)通过为Proxy类指定ClassLoader对象和一组interface来创建动态代理类

3)通过反射机制获得动态代理类的构造函数,其唯一参数类型是调用处理器接口类型

4)通过构造函数创建动态代理类实例,构造时调用处理器对象作为参数被传入

2、创建代理

//InvocationHandlerImpl 实现了InvocationHandler接口,并能实现方法调用从代理类到委托类的分派转发

//其内部通常包含指向委托类实例的引用,用于真正执行分派转发过来的方法调用

InvocationHandler handler = new InvocaitonHandlerImpl(..);

//通过Proxy为包括Interface接口在内的一组接口动态创建代理类的对象

Class clazz = Proxy.getProxyClass(classLoader,new Class[]{Interface.class,...});

//通过反射从生成的类对象获得构造函数对象

Constructor constructor = clazz.getConstructor(new Class[]{InvocationHandler.class});

//通过构造函数对象创建动态代理类实例

Interface Proxy = (Interface)constructor.newInstance(new Object[]{handler});

//Proxy类的静态方法newProxyInstance对上面具体步骤的后三步做了封装,简化了动态代理对象的获取过程。

//InvocationHandlerImpl实现了InvocaitonHandler接口,并能实现方法调用从代理类到委托类的分派转发

InvocaitonHandler handler = new InvocationHandlerImpl(..);

//通过Proxy直接创建动态代理类实例

nterface proxy = (Interface)Proxy.newProxyInstance(classLoader,new Class[]{Interface.class},handler);

3、代码

/**

* 接口

*

*/

public interface IDBQuery {

String request();

}

/**

* 真实的实现类,具体的目标对象

*

*/

public class DBQuery implements IDBQuery {

public DBQuery(){

try {

Thread.sleep(1000); //可能包含数据库连接等耗时操作

} catch (InterruptedException e) {

e.printStackTrace();

}

}

@Override

public String request() {

return "request string";

}

}

/**

* JDK动态代理的实现类

*

*/

public class JdkDbQueryHandler implements InvocationHandler{

IDBQuery real = null; //主题接口

/**

* 生成Handler

*/

@Override

public Object invoke(Object proxy, Method method, Object[] args)

throws Throwable {

if(real == null)

real = new DBQuery(); //如果是第一次调用,则生成真实对象

return real.request(); //使用真实主题完成实际的操作

}

/**

* 利用Handler生成动态代理对象

*/

public static IDBQuery createJdkProxy(){

//根据指定的类加载器和接口以及截获器,返回代理类的一个实例对象

//ClassLoader loader :指定被代理对象的类加载器

//Class[] Interfaces :指定被代理对象所以事项的接口

//InvocationHandler h :指定需要调用的InvocationHandler对象

IDBQuery jdkProxy = (IDBQuery) Proxy.newProxyInstance(ClassLoader.getSystemClassLoader(), new Class[]{IDBQuery.class}, new JdkDbQueryHandler());

return jdkProxy;

}

}

关于java多级代理和代理Java的介绍到此就结束了,不知道你从中找到你需要的信息了吗 ?如果你还想了解更多这方面的信息,记得收藏关注本站。

The End

发布于:2022-11-28,除非注明,否则均为首码项目网原创文章,转载请注明出处。