您的位置:首页 > 运维架构

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

2015-12-11 11:09 323 查看
代理模式

抽象角色:真实对象和代理对象的共同接口

代理角色:秘书

真实角色(被代理角色):局长

实现代理接口&&调用转发

创建动态代理步骤:
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动态代理