6.hadoop中rpc中的动态代理的理解

代理模式
抽象角色:真实对象和代理对象的 共同接口
代理角色秘书
真实角色(被代理角色)局长

实现代理接口&&调用转发
创建动态代理步骤:
1.创建一个实现接口InvocationHandler的类,它必须实现invoke方法
2.创建被代理的类以及接口
3.通过Proxy的静态方法 newProxyInstance(ClassLoader loader,Class[] interfaces,InvocationHander h)创建一个代理
4.通过代理调用方法

动态代理类位于 java.lang.reflect包下,主要涉及以下两个类:
(1) Proxy:
该类即为动态代理类,其中主要包含以下内容:
  • Protected Proxy(InvocationHandler h):构造函数,用于给内部的h赋值。
  • static Class getProxyClass(ClassLoader loader,Class[] interfaces):获得一个代理类,其中loader是类装载器,interfaces是真实类所拥有的全部接口的数组。
  • static Object newProxyInstance(ClassLoader loader,Class[] interfaces,InvocationHander h):返回代理类的一个实例,返回后的代理类可以当作被代理类使用
(2)InvocationHandler<Interface > :
该接口中仅定义了一个方法:
  • public Object invoke(Object obj,Method method,Object[] args)
在实际使用时,第一个参数obj一般是指代理对象本身,method是指用户调用的代理对象上的方法,args为该方法的参数数组。这个抽象方法在代理类中被动态实现。
所谓Dynamic Proxy是这样一种class:它是在运行时生成的class,在生成它时你必须提供一组 interface给它,然后该class就宣称它实现了这些interface。

你当然可以把该class的实例当作这些interface中任何一个来用。当然,这个Dynamic Proxy其实就是一个Proxy,它不会替你作实质性的工作,在生成它的实例时你必须提供一个handler,由它接管实际的工作。通过这种方式,被代理的对象(RealSubject)可以在运行时动态改变,需要控制的接口可以在运行时改变,控制的方式也可以动态改变,从而实现了非常灵活的动态代理关系。
动态代理是指客户通过代理类调用其它对象的方法。

你可能感兴趣的:(rpc动态代理)