简简单单的代码让你轻松学会动态代理
前言:
最近一直在分析hadoop的RPC机制。在hadoop中,DataNode和NameNode之间的控制信息的交流是通过RPC机制完成的,采用的是动态代理和java NIO(参考博客:http://weixiaolu.iteye.com/blog/1479656
) 的方式。DataNode端是通过获得NameNode的代理,通过该代理和NameNode进行通信的,为了更好的分析hadoop的RPC机制我想先分析一下动态代理是怎么实现。下面就是动态代理的最最简单的代码实现,我们一起来看看吧。
代码如下:
package cn.xiaolu;
import java.lang.reflect.InvocationHandler;
import java.lang.reflect.Method;
import java.lang.reflect.Proxy;
/**
* 动态代理类使用到了一个接口InvocationHandler和一个代理类Proxy ,这两个类配合使用实现了动态代理的功能。
* 那么什么是动态代理呢?
* 我们平常说的代理类是指: 给每个具体类写一个代理类,以后要使用某个具体类时,只要创建它的代理类的对象,然后调用代理类的方法就可以了。
* 可是如果现在有许多的具体类,那就需要有许多的代理类才可以,这样很显然不合适。所以动态代理就应运而生了,我们只要写一个类实现
* InvocationHandler 并实现它的invoke方法,然后再用Proxy的工厂方法newProxyInstance()创建一个代理对象,这个对象同样可以实现对具体类的代理功能。
* 而且想代理哪个具体类,只要给Handler(以下代码中的Invoker)的构造器传入这个具体对象的实例就可以了。感觉是不是自己为该具体类造了一个代理类呢?呵呵~
*/
//接口类
interface AbstractClass {
public void show();
}
// 具体类A
class ClassA implements AbstractClass {
@Override
public void show() {
// TODO Auto-generated method stub
System.out.println("我是A类!");
}
}
// 具体类B
class ClassB implements AbstractClass {
@Override
public void show() {
// TODO Auto-generated method stub
System.out.println("我是B类!");
}
}
//动态代理类,实现InvocationHandler接口
class Invoker implements InvocationHandler {
AbstractClass ac;
public Invoker(AbstractClass ac) {
this.ac = ac;
}
@Override
public Object invoke(Object proxy, Method method, Object[] arg)
throws Throwable {
//调用之前可以做一些处理
method.invoke(ac, arg);
//调用之后也可以做一些处理
return null;
}
}
/**
* 测试类
* @author 小路
*/
class DynamicProxyTest {
public static void main(String[] args) {
//创建具体类ClassB的处理对象
Invoker invoker1=new Invoker(new ClassA());
//获得具体类ClassA的代理
AbstractClass ac1 = (AbstractClass) Proxy.newProxyInstance(
AbstractClass.class.getClassLoader(),
new Class[] { AbstractClass.class }, invoker1);
//调用ClassA的show方法。
ac1.show();
//创建具体类ClassB的处理对象
Invoker invoker2=new Invoker(new ClassB());
//获得具体类ClassB的代理
AbstractClass ac2 = (AbstractClass) Proxy.newProxyInstance(
AbstractClass.class.getClassLoader(),
new Class[] { AbstractClass.class }, invoker2);
//调用ClassB的show方法。
ac2.show();
}
}
程序运行后的结果如下:
我是A类!
我是B类!
很快我会写一篇关于hadoop RPC机制分析的博客,博客地址:http://weixiaolu.iteye.com/blog/1504898
,希望大家继续关注。
分享到:
相关推荐
5. **用户界面**:提供友好的交互界面,如播放进度条、音量控制、歌曲列表等,让用户可以轻松操作播放器。 在“SimpleMP3”这个项目中,源代码可能涵盖了上述所有部分。开发者可能使用了一种常见的编程语言,如C++...
简简单单清除系统lj 可执行文件 .bat
通过"简简单单的C实例"这个压缩包,我们可以期待找到一些简单的源代码示例,如打印"Hello, World!"、计算两数之和、实现简单的循环或条件判断等。这些实例将帮助初学者逐步理解并掌握C语言的基本语法和编程思想。...
【标题】:“简简单单学习ASP.NET” 【描述】:“简简单单学习ASP.NET简简单单学习ASP.NET简简单单学习ASP.NET” 【标签】:“ASP.NET” 【部分内容】: 在学习ASP.NET之前,我们需要先了解一些基础的WEB开发...
这种布局方式不仅让界面看起来整洁有序,也方便用户识别和操作不同的功能按钮。 ### 2. 按钮与事件监听 #### 数字与运算符按钮 程序中定义了一个`Button`数组`s`,其中包含了从“0”到“9”的数字按钮以及“/”、...
标题中的“win10卸载edge的简简单单工具”指的是在Windows 10操作系统中,用户想要卸载预装的Microsoft Edge浏览器。通常,Windows系统内置的应用程序并不容易通过常规的控制面板或设置菜单卸载,特别是Edge,因为它...
简简单单学习ASP.NET.doc简简单单学习ASP.NET.doc简简单单学习ASP.NET.doc简简单单学习ASP.NET.doc简简单单学习ASP.NET.doc简简单单学习ASP.NET.doc简简单单学习ASP.NET.doc简简单单学习ASP.NET.doc简简单单学习ASP...
3. **用户界面(UI)**:简简单单的播放器可能具有直观且用户友好的界面,没有过多复杂的设置和选项,使得初学者也能轻松上手。 4. **可执行文件(Exe)**:在Windows系统中,.exe文件是程序的载体,包含了执行程序所需...
这款“简简单单风格”可能是为了提供一个简洁、直观的界面,让用户在浏览和参与论坛讨论时更加舒适和高效。 【描述】"简简单单风格for bbsxp" 强调了设计的核心理念是简约。这通常意味着去除不必要的装饰元素,使...
超级简单好用的股票走势图代码,简简单单的在网站里面插入某只股票的走势图和K线图。
在.NET开发环境中,数据分页是一项常见的需求,特别是在处理大量数据时,为了提高用户体验和页面加载速度,我们通常会将数据分成多个小部分,也就是页,让用户逐页浏览。本教程将详细介绍如何“简简单单实现数据分页...
它允许开发人员将源代码、编译后的二进制文件、文档等资源便捷地分享到一个集中位置,供团队成员访问。这极大地提高了协作效率,尤其是当团队成员分布在不同的地理位置时。 SlimFTPd是一款符合这个描述的FTP服务器...
《简简单单的客户管理系统》 在信息技术日新月异的今天,客户关系管理(Customer Relationship Management,简称CRM)已经成为企业提升效率、增强竞争力的重要工具。一个“简简单单的客户管理系统”旨在为企业提供...
简简单单看文件.doc
【标题】JJDD-Blog(简简单单博客).7z是一个压缩包文件,根据其名称推测,这可能是一个关于个人博客系统的源代码包。7z格式是7-Zip软件所使用的高效压缩格式,以高压缩比和广泛支持多种文件类型而知名。 【描述】...
教你简简单单小技巧 破解上万注册码 网上有许多令人心动的共享软件,可惜的是它们或多或少都存在各种限制...