Proxy.newProxyInstance实现动态代理

Java动态代理:Proxy.newProxyInstance详解
本文探讨了Java中使用Proxy.newProxyInstance实现动态代理的原理,讲解了如何为给定接口创建代理类,并重点阐述了InvocationHandler接口及其invoke()方法在代理执行过程中的作用。
部署运行你感兴趣的模型镜像
    @CallerSensitive
    public static Object newProxyInstance(ClassLoader var0, Class<?>[] var1, InvocationHandler var2) throws IllegalArgumentException {
        // 判断InvocationHandler是否为空,动态代理方法在执行时,会调用var2里面的invoke方法去执行
        Objects.requireNonNull(var2);
        // 生成一个实现参数interfaces(new Class<?>[] { clazz)里面所有接口,继承了Proxy的代理类的字节码;然后用参数里面的clazz.getClassLoader()加载这个代理类
        Class[] var3 = (Class[])var1.clone();
        // 对传入的接口var1进行安全检查checkProxyAccess
        SecurityManager var4 = System.getSecurityManager();
        if (var4 != null) {
            checkProxyAccess(Reflection.getCallerClass(), var0, var3);
        }
		// 动态代理的核心,生成一个新类var5
        Class var5 = getProxyClass0(var0, var3);
		// 将这个新类完善
        try {
            if (var4 != null) {
                checkNewProxyPermission(Reflection.getCallerClass(), var5);
            }
            // 通过反射,获取构造函数对象
	// private static final Class<?>[] constructorParams = new Class[]{InvocationHandler.class};
            final Constructor var6 = var5.getConstructor(constructorParams);
            if (!Modifier.isPublic(var5.getModifiers())) {
                AccessController.doPrivileged(new PrivilegedAction<Void>() {
                    public Void run() {
                        var6.setAccessible(true);
                        return null;
                    }
                });
            }
         // 使用代理类父类的构造函数Proxy(InvocationHandler handler)来创造一个代理类的实例;将我们自定义的InvocationHandler 的子类传入;
		// 生成代理类实例
            return var6.newInstance(var2);
        } catch (InstantiationException | IllegalAccessException var8) {
            throw new InternalError(var8.toString(), var8);
        } catch (InvocationTargetException var9) {
            Throwable var7 = var9.getCause();
            if (var7 instanceof RuntimeException) {
                throw (RuntimeException)var7;
            } else {
                throw new InternalError(var7.toString(), var7);
            }
        } catch (NoSuchMethodException var10) {
            throw new InternalError(var10.toString(), var10);
        }
    }

举个栗子

InvocationHandler handler = new ServiceHandler(clazz);
Object  proxy = Proxy.newProxyInstance(clazz.getClassLoader(), new Class<?>[] { clazz }, handler);

其中clazz需要实现一个接口,动态生成的代理类 $Proxy0.class,实现这个接口。这个接口就是提供一个自己的类到proxy之间的桥梁。并且继承Proxy。执行InvocationHandler对象的invoke()方法的时候就是执行父类中的invoke方法;

您可能感兴趣的与本文相关的镜像

Linly-Talker

Linly-Talker

AI应用

Linly-Talker是一款创新的数字人对话系统,它融合了最新的人工智能技术,包括大型语言模型(LLM)、自动语音识别(ASR)、文本到语音转换(TTS)和语音克隆技术

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值