JDK动态代理的底层实现原理

JDK动态代理的底层实现原理

JDK动态代理的底层实现原理_第1张图片

JDK是怎么生成代理类并且实例化的:

核心代码就是:

Proxy.newProxyInstance(this.getClass().getClassLoader(),target.getClass().getInterfaces(),this);

看看JDK的底层实现:

JDK动态代理的底层实现原理_第2张图片

通过源码可以知道,生成代理类是通过如下方法实现的:

Class cl =getProxyClass(loader, interfaces);

再追踪一下,这个方法里面内容很多,但是最关键的就是下面这个方法:

byte[] proxyClassFile = ProxyGenerator.generateProxyClass(proxyName, interfaces);

通过这个方法就生成了代理类的字节码,

JDK动态代理的底层实现原理_第3张图片

可以看到生成的动态代理类其实跟静态代理类还是有区别的,静态代理是我们直接控制真实对象的方法调用,而动态代理是通过调用处理器的invoke方法来调用真实对象的方法,而这个invoke方法就是我们自己覆写的方法,

JDK动态代理的底层实现原理_第4张图片

可以看出是通过反射实现的,通过传入的不同的方法对象和参数来调用真实对象的不同方法。对于invoke方法发参数,Method和args在我们覆写的invoke方法中都有用到,但是对于第一个参数,代理对象proxy没有用,所以不知道这个东西调用处理器传给我们有什么用,最后通过谷歌和百度搜索得到答案:

1.可以使用反射获取代理对象的信息(也就是proxy.getClass().getName())。

2.可以将代理对象返回以进行连续调用,这就是proxy存在的目的(因为this并不是代理对象)。

你可能感兴趣的:(JDK动态代理的底层实现原理)