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)可以在运行时动态改变,需要控制的接口可以在运行时改变,控制的方式也可以动态改变,从而实现了非常灵活的动态代理关系。
动态代理是指客户通过代理类调用其它对象的方法。
抽象角色:真实对象和代理对象的共同接口
代理角色:秘书
真实角色(被代理角色):局长
实现代理接口&&调用转发
创建动态代理步骤:
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)可以在运行时动态改变,需要控制的接口可以在运行时改变,控制的方式也可以动态改变,从而实现了非常灵活的动态代理关系。
动态代理是指客户通过代理类调用其它对象的方法。
相关文章推荐
- nginx配置详解
- 随机显示TOP 8 条记录
- python调用shell脚本
- 【转】字符设备模型
- 4.hadoop中的压缩
- 3.hadoop中的序列化
- 2.hadoop配置信息处理
- 深入理解SELinux SEAndroid之二
- 1.hadoop的认识
- OpenSceneGraph几个重要功能节点练习
- 下拉列表框DropDownList绑定Dictionary泛型类
- shell调用脚本--直接退出不执行后续命令
- centos7中mysql自带压测工具mysqlslap使用
- 搭建Hadoop集群中遇到的坑
- opencv 读取rgb.txt 并显示出来
- hadoop学习博客
- 5. storm常用命令(客户端storm shell)
- 编译opencv文件
- 拓扑排序(topological sort)
- hive shell执行命令报错:Specified key was too long; max key length is 767 bytes