`

简简单单的代码让你轻松学会动态代理

 
阅读更多

转:http://weixiaolu.iteye.com/blog/1477774

 

最近一直在分析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 ,希望大家继续关注。

分享到:
评论

相关推荐

    简简单单MP3播放器的源代码

    5. **用户界面**:提供友好的交互界面,如播放进度条、音量控制、歌曲列表等,让用户可以轻松操作播放器。 在“SimpleMP3”这个项目中,源代码可能涵盖了上述所有部分。开发者可能使用了一种常见的编程语言,如C++...

    简简单单清除系统lj

    简简单单清除系统lj 可执行文件 .bat

    简简单单的C实例

    通过"简简单单的C实例"这个压缩包,我们可以期待找到一些简单的源代码示例,如打印"Hello, World!"、计算两数之和、实现简单的循环或条件判断等。这些实例将帮助初学者逐步理解并掌握C语言的基本语法和编程思想。...

    简简单单学习ASP.NET

    【标题】:“简简单单学习ASP.NET” 【描述】:“简简单单学习ASP.NET简简单单学习ASP.NET简简单单学习ASP.NET” 【标签】:“ASP.NET” 【部分内容】: 在学习ASP.NET之前,我们需要先了解一些基础的WEB开发...

    一个简简单单的计算器

    这种布局方式不仅让界面看起来整洁有序,也方便用户识别和操作不同的功能按钮。 ### 2. 按钮与事件监听 #### 数字与运算符按钮 程序中定义了一个`Button`数组`s`,其中包含了从“0”到“9”的数字按钮以及“/”、...

    win10卸载edge的简简单单工具

    标题中的“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.NET.doc简简单单学习ASP...

    简简单单MP3播放器的可执行程序

    3. **用户界面(UI)**:简简单单的播放器可能具有直观且用户友好的界面,没有过多复杂的设置和选项,使得初学者也能轻松上手。 4. **可执行文件(Exe)**:在Windows系统中,.exe文件是程序的载体,包含了执行程序所需...

    简简单单风格 for bbsxp 5.0

    这款“简简单单风格”可能是为了提供一个简洁、直观的界面,让用户在浏览和参与论坛讨论时更加舒适和高效。 【描述】"简简单单风格for bbsxp" 强调了设计的核心理念是简约。这通常意味着去除不必要的装饰元素,使...

    网页插入股票代码

    超级简单好用的股票走势图代码,简简单单的在网站里面插入某只股票的走势图和K线图。

    简简单单实现数据分页

    在.NET开发环境中,数据分页是一项常见的需求,特别是在处理大量数据时,为了提高用户体验和页面加载速度,我们通常会将数据分成多个小部分,也就是页,让用户逐页浏览。本教程将详细介绍如何“简简单单实现数据分页...

    简简单单的FTP server

    它允许开发人员将源代码、编译后的二进制文件、文档等资源便捷地分享到一个集中位置,供团队成员访问。这极大地提高了协作效率,尤其是当团队成员分布在不同的地理位置时。 SlimFTPd是一款符合这个描述的FTP服务器...

    简简单单的客户管理系统

    《简简单单的客户管理系统》 在信息技术日新月异的今天,客户关系管理(Customer Relationship Management,简称CRM)已经成为企业提升效率、增强竞争力的重要工具。一个“简简单单的客户管理系统”旨在为企业提供...

    简简单单看文件.doc

    简简单单看文件.doc

    JJDD-Blog(简简单单博客).7z

    【标题】JJDD-Blog(简简单单博客).7z是一个压缩包文件,根据其名称推测,这可能是一个关于个人博客系统的源代码包。7z格式是7-Zip软件所使用的高效压缩格式,以高压缩比和广泛支持多种文件类型而知名。 【描述】...

    教你简简单单小技巧 破解上万注册码

    教你简简单单小技巧 破解上万注册码 网上有许多令人心动的共享软件,可惜的是它们或多或少都存在各种限制...

Global site tag (gtag.js) - Google Analytics