RPC(远程过程调用)简单来说,调用者看似调用的是本地的方法,其实调用的是代理的方法,代理方法中实现了从序列化、网络传输以及反序列化等操作
1、应用层协议
2、创新点在于透明化,调用者像是调用本地方法一样
3、应用之间互相调用
代理模式:为其他对象提供一种代理以控制对这个对象的访问。
Spring 两种动态代理方式
JDK代理
1、只能代理接口,因为代理方式是生成代理子类,如下图的$Proxy0,由于不能多继承,所以不能再继承需要代理的目标类了,只能实现接口
2、利用反射在生成的代理子类( $ Proxy0)中执行父类(Proxy)代理的目标方法()
2、jdk代理例子
Cglib代理:
通过ASM框架直接操作字节码生成代理类的二进制字节码文件,
加载二进制字节码,生成Class对象( 例如使用Class.forName()方法 );
通过反射机制获得实例构造,并创建代理类对象执行
代理方式 | 实现 | 优点 | 缺点 | 特点 |
---|---|---|---|---|
JDK静态代理 | 代理类与委托类实现同一接口,并且在代理类中需要硬编码接口 | 实现简单,容易理解 | 代理类需要硬编码接口,在实际应用中可能会导致重复编码,浪费存储空间并且效率很低 | 好像没啥特点 |
JDK动态代理 | 代理类与委托类实现同一接口,主要是通过代理类实现InvocationHandler并重写invoke方法来进行动态代理的,在invoke方法中将对方法进行增强处理 | 不需要硬编码接口,代码复用率高 | 只能够代理实现了接口的委托类 | 底层使用反射机制进行方法的调用 |
CGLIB动态代理 | 代理类将委托类作为自己的父类并为其中的非final委托方法创建两个方法,一个是与委托方法签名相同的方法,它在方法中会通过super调用委托方法;另一个是代理类独有的方法。在代理方法中,它会判断是否存在实现了MethodInterceptor接口的对象,若存在则将调用intercept方法对委托方法进行代理 | 可以在运行时对类或者是接口进行增强操作,且委托类无需实现接口 | 不能对final类以及final方法进行代理 | 底层将方法全部存入一个数组中,通过数组索引直接进行方法调用 |