博客 design principle:模拟 android Button 控件点击事件 主要说了一下模拟 android 的 Listener 模式,其实这就是一种委派与回调机制的体现。


委派,也可以叫做委托,从字面上来理解的话,应该是委托其他类做事情而自己不做或者只做一部分工作;而回调,就是调用自己的方法。


在 java 中,这两种机制很类似,你姑且可以认为它们就是一码事。


推荐一篇博文给大家: Java中委托事件模型


java 中,实现委派和回调都是通过接口来实现的。下面举个小例子吧!


该例子是这样的(只是一个例子):


ProfessionalWorker 、SparetimeWorker 负责发射 Rocket,Rocket 类通过接口 IRocketDelegate 委派(或者说是回调) ProfessionalWorker 、SparetimeWorker自己发射。


总之,Rocket不做具体的事情。看实例代码:


IRocketDelegate.java源码

public interface IRocketDelegate {  

    public abstract long startAtTime();  

    public abstract long endAtTime();  

    public abstract void sendDidFail();
}  

共有三个方法,分别是用于计算 Rocket 发射时间、计算 Rocket 发射完毕的时间以及发送是否失败的。


Rocket.java源码

public class Rocket {  

    IRocketDelegate delegate = null;  

    public Rocket(IRocketDelegate delegate) {
        this.delegate = delegate;
    }  

    private long getRocketStartTime() {
        long startTime = delegate.startAtTime();
        return startTime;
    }  

    private long getRocketEndTime() {
        long endTime = delegate.endAtTime();
        return endTime;
    }  

    public boolean isOk() {
        // 超时0.1秒为失败
        if (getRocketEndTime() - getRocketStartTime() >= 100) {
            delegate.sendDidFail();
            return false;
        }
        return true;
    }  

}  

在这个类中,声明一个 IRocketDelegate 接口对象,使用该对象调用接口的方法。我们知道,接口不可以直接实例化,换句话说,实例化接口必须实现接口的所有方法。


那么,我们就把这些实现工作交给具体的发射者来完成。实现回调。


ProfessionalWorker.java源码

public class ProfessionalWorker implements IRocketDelegate {  

    @Override
    public long startAtTime() {
        System.out.println("startAtTime is call-back inProfessionalWorker!");
        return System.currentTimeMillis();
    }  

    @Override
    public long endAtTime() {
        System.out.println("endAtTime is call-back in ProfessionalWorker!");
        return System.currentTimeMillis();
    }  

    @Override
    public void sendDidFail() {
        System.out.println("ProfessionalWorker send Rocket fail !");
    }  

    public void send() {
        if (new Rocket(this).isOk()) {
            System.out.println("ProfessionalWorker send Rocket ok !");
        }
    }
}  


SparetimeWorker.java源码

public class SparetimeWorker {
    public void send() {
        boolean isOk = new Rocket(new IRocketDelegate() {  

            @Override
            public long startAtTime() {
                System.out.println("startAtTime is call-back in SparetimeWorker !");
                return System.currentTimeMillis();
            }  

            @Override
            public long endAtTime() {
                System.out.println("endAtTime is call-back in SparetimeWorker!");
                return System.currentTimeMillis() + 100L;
            }  

            @Override
            public void sendDidFail() {
                System.out.println("SparetimeWorker send Rocket fail !");
            }
        }).isOk();  

        if(isOk) {
            System.out.println("SparetimeWorker send Rocket ok !");
        }
    }
}  

这个类采用内部类的方式完成。


Test.java

public class Test {  

    public static void main(String[] args) {
        new ProfessionalWorker().send();  

        System.out.println("*********************************************");  

        new SparetimeWorker().send();
    }
}  

显示结果

endAtTime is call-back in ProfessionalWorker!
startAtTime is call-back inProfessionalWorker!
ProfessionalWorker send Rocket ok !
*********************************************
endAtTime is call-back in SparetimeWorker!
startAtTime is call-back in SparetimeWorker !
SparetimeWorker send Rocket fail !  

这就体现 Java 中的一句话 Don't call me,I'll call you. 其含义就是回调(或者委派/委托)。


android 中很多这样的用法,关于接口的好处还有很多,后续慢慢研究,记住一句话:面向对象面向接口编程。

design principle:java 回调与委派/委托机制的更多相关文章

  1. java类加载器及其委托机制

    1.什么是类加载器,类加载器父子结构.BootStrap-->ExtClassLoader-->AppClassLoader,级别依次降低 2.类加载器之间的父子关系和管辖范围 3.类加载 ...

  2. 破坏双亲委托机制的一些情况---Tomcat和JDBC,破坏后的安全问题

    采用双亲委托机制的原因 类加载器就是将字节码搬进jvm方法区的组件.我们知道,JVM识别加载进来的类是通过类加载器+类全名完成的,也就是说同一个类由不同类加载器加载进去的话就会被视为不同的类.jdk提 ...

  3. 关于Java类加载双亲委派机制的思考(附一道面试题)

    预定义类加载器和双亲委派机制 JVM预定义的三种类型类加载器: 启动(Bootstrap)类加载器:是用本地代码实现的类装入器,它负责将 <Java_Runtime_Home>/lib下面 ...

  4. Java 类加载体系之 ClassLoader 双亲委托机制

    Java 类加载体系之 ClassLoader 双亲委托机制 java 是一种类型安全的语言,它有四类称为安全沙箱机制的安全机制来保证语言的安全性,这四类安全沙箱分别是: 类加载体系 .class文件 ...

  5. ClassLoader类加载器 & Java类加载机制 & 破坏双亲委托机制

    ClassLoader类加载器 Java 中的类加载器大致可以分成两类: 一类是系统提供的: 引导类加载器(Bootstrap classloader):它用来加载 Java 的核心库(如rt.jar ...

  6. Java虚拟机JVM学习06 自定义类加载器 父委托机制和命名空间的再讨论

    Java虚拟机JVM学习06 自定义类加载器 父委托机制和命名空间的再讨论 创建用户自定义的类加载器 要创建用户自定义的类加载器,只需要扩展java.lang.ClassLoader类,然后覆盖它的f ...

  7. Java虚拟机JVM学习05 类加载器的父委托机制

    Java虚拟机JVM学习05 类加载器的父委托机制 类加载器 类加载器用来把类加载到Java虚拟机中. 类加载器的类型 有两种类型的类加载器: 1.JVM自带的加载器: 根类加载器(Bootstrap ...

  8. java类加载器学习2——自定义类加载器和父类委托机制带来的问题

    一.自定义类加载器的一般步骤 Java的类加载器自从JDK1.2开始便引入了一条机制叫做父类委托机制.一个类需要被加载的时候,JVM先会调用他的父类加载器进行加载,父类调用父类的父类,一直到顶级类加载 ...

  9. java回调机制及其实现(转)

    1. 什么是回调函数 回调函数,顾名思义,用于回调的函数.回调函数只是一个功能片段,由用户按照回调函数调用约定来实现的一个函数.回调函数是一个工作流的一部分,由工作流来决定函数的调用(回调)时机.回调 ...

随机推荐

  1. WebService之soap类型的服务和rest类型的服务

    1.引言 WebService顾名思义就是web服务,web服务主要有两种,一种是基于soap类型的服务,一种是基于rest类型的服务,其中soap类型的服务有两种版本,一种是soap1.1版本,一种 ...

  2. linux常用命令随记

    常用指令 ls 显示文件或目录 -l 列出文件详细信息l(list) -a 列出当前目录下所有文件及目录,包括隐藏的a(all) mkdir 创建目录 -p 创建目录,若无父目录,则创建p(paren ...

  3. Nginx 安装 配置 使用

    Nginx 安装 配置 使用 基本的HTTP服务器特性 处理静态文件,索引文件以及自动索引:打开文件描述符缓存(缓存元数据和文件描述符,下一次可以直接从内存找到数据或者文件的位置): 使用缓存加速反向 ...

  4. 基本数据类型 异常 数组排序 JVM区域划分

               Day01 1.基本数据类型各占几个字节 Byte 1 short2 int4 long8 float4 double6 char2 boolean1 Byte b1=3,b2= ...

  5. H5--Web Worker

    Web Worker是H5的新特性. JS是单线程的,所以在消息队列中如果用户想进行一些阻塞操作,比如时延timeout和定时器interval,或者是数据量较大及处理过程非常长的场景,就很容易出现页 ...

  6. CSS中display:block属性的作用

    display:block可以理解为块,举个简单的例子!比如你做一个超链接,<li><a href="#">超链接</a></li> ...

  7. Django中过期@cache_page中缓存的views数据

    django的缓存系统中,cache_page 这个装饰器非常好用,只要添加一个装饰器就可以缓存views的响应内容,但是django没有提供过期这个views缓存数据的功能. @cache_page ...

  8. JAVA Eclipse使用Maven构建web项目详解(SSM框架)

    tips: 启动项目后,welcome-file的链接即为测试用例 部署maven web项目 Eclipse使用Maven构建web项目详解 pom.xml添加webapp依赖: <depen ...

  9. RunLoop总结:RunLoop基础知识

    没有实际应用场景,很难理解一些抽象空洞的东西,所以前面几篇文章先介绍了RunLoop的几个使用场景. 另外AsyncDisplayKit中也有大量使用RunLoop的示例. 关于实际的使用RunLoo ...

  10. Zookeeper核心工作机制(zookeeper特性、zookeeper数据结构、节点类型)

    10.1 zookeeper特性 1.Zookeeper:一个leader,多个follower组成的集群. 2.全局数据一致:每个server保存一份相同的数据副本,client无论连接到哪个ser ...