源代码直接搬的JavaGuide动态代理的源码,仅在main函数加了个 Method[] aClass = smsService.getClass().getDeclaredMethods();
主要要看的就是Proxy的newProxyInstance()方法
//核心代码1,得到真正的代理对象$Proxy0,这里就不继续深挖代码了,浅看了一下都涉及到gc的不可达节点了好像,应该不用了解那么深
Class<?> cl = getProxyClass0(loader, intfs);
//得到代理对象的构造方法
final Constructor<?> cons = cl.getConstructor(constructorParams);
//引用形参传进来的自定义InvocationHandler
final InvocationHandler ih = h;
//调用$Proxy0的构造方法传入自定义InvocationHandler并实例化
return cons.newInstance(new Object[]{h});
顺便截图可以看到$Proxy0把被代理对象的send()方法直接构造出来了

参考了其他人的分析知道,这个send()方法调的其实是自定义InvocationHandler的invoke方法,不然就不可能叫代理对象了
文章详细解读了Java动态代理的实现,特别是Proxy的newProxyInstance()方法。通过创建$Proxy0类并利用InvocationHandler,代理对象能调用原始对象的方法,如send(),实际上是执行InvocationHandler的invoke方法。此过程涉及类加载和构造器的使用。
1113

被折叠的 条评论
为什么被折叠?



