zoukankan      html  css  js  c++  java
  • 回调函数

    程序员A写了一段程序(程序a),其中预留有回调函数接口,并封装好了该程序。程序员B要让a调用自己的程序b中的一个方法,于是,他通过a中的接口回调自己b中的方法。目的达到。在C/C++中,要用回调函数,被掉函数需要告诉调用者自己的指针地址,但在JAVA中没有指针,怎么办?我们可以通过接口(interface)来实现定义回调函数。
    假设我是程序员A,以下是我的程序a:
    public class Caller
    {
    public MyCallInterface mc;
     
    public void setCallfuc(MyCallInterface mc)
    {
    this.mc= mc;
    }
     
    public void call(){
    this.mc.method();
    }
    }
     
     
    我还需要定义一个接口,以便程序员B根据我的定义编写程序实现接口。
     
    public interface MyCallInterface
    {
    public void method();
     
    }
     
    于是,程序员B只需要实现这个接口就能达到回调的目的了:
     
    public class B implements MyCallInterface
    {
    public void method()
    {
    System.out.println("回调");
    }
     
    public static void main(String args[])
    {
    Caller call = new Caller();
    call.setCallfuc(new B());
    call.call();
    }
    }
     
     

    ---------------------------------------------------------------------------------------------------------------------------------

    ---------------------------------------------------------------------------------------------------------------------------------

    再看一个异步回调的
    /**
    * 这是一个回调接口
    * @author xiaanming
    *
    */
    public interface CallBack {
    /**
    * 这个是小李知道答案时要调用的函数告诉小王,也就是回调函数
    * @param result 是答案
    */
    public void solve(String result);
    }
     
    [java] view plain copy
    /**
    * 这个是小王
    * @author xiaanming
    * 实现了一个回调接口CallBack,相当于----->背景一
    */
    public class Wang implements CallBack {
    /**
    * 小李对象的引用
    * 相当于----->背景二
    */
    private Li li;
     
    /**
    * 小王的构造方法,持有小李的引用
    * @param li
    */
    public Wang(Li li){
    this.li = li;
    }
     
    /**
    * 小王通过这个方法去问小李的问题
    * @param question 就是小王要问的问题,1 + 1 = ?
    */
    public void askQuestion(final String question){
    //这里用一个线程就是异步,
    new Thread(new Runnable() {
    @Override
    public void run() {
    /**
    * 小王调用小李中的方法,在这里注册回调接口
    * 这就相当于A类调用B的方法C
    */
    li.executeMessage(Wang.this, question);
    }
    }).start();
     
    //小网问完问题挂掉电话就去干其他的事情了,诳街去了
    play();
    }
     
    public void play(){
    System.out.println("我要逛街去了");
    }
     
    /**
    * 小李知道答案后调用此方法告诉小王,就是所谓的小王的回调方法
    */
    @Override
    public void solve(String result) {
    System.out.println("小李告诉小王的答案是--->" + result);
    }
     
    }
     
     
    [java] view plain copy
    /**
    * 这个就是小李啦
    * @author xiaanming
    *
    */
    public class Li {
    /**
    * 相当于B类有参数为CallBack callBack的f()---->背景三
    * @param callBack
    * @param question 小王问的问题
    */
    public void executeMessage(CallBack callBack, String question){
    System.out.println("小王问的问题--->" + question);
     
    //模拟小李办自己的事情需要很长时间
    for(int i=0; i<10000;i++){
     
    }
     
    /**
    * 小李办完自己的事情之后想到了答案是2
    */
    String result = "答案是2";
     
    /**
    * 于是就打电话告诉小王,调用小王中的方法
    * 这就相当于B类反过来调用A的方法D
    */
    callBack.solve(result);
     
     
     
    }
     
    }
     
     
    [java] view plain copy
    /**
    * 测试类
    * @author xiaanming
    *
    */
    public class Test {
    public static void main(String[]args){
    /**
    * new 一个小李
    */
    Li li = new Li();
     
    /**
    * new 一个小王
    */
    Wang wang = new Wang(li);
     
    /**
    * 小王问小李问题
    */
    wang.askQuestion("1 + 1 = ?");
    }
    }
  • 相关阅读:
    阅读心得10:《京东咚咚架构演进 》
    hadoop beginning
    ubuntu docker
    Ubuntu学习——第一篇
    flexsim diary
    apollo 3.0 硬件系统
    这是一份详细的Apollo自动驾驶平台上手指南
    详解百度Apollo感知技术、高精地图和小度车载系统
    Apollo 2.5推基于动态的实时相对地图解决方案
    Apollo在功能安全方面的探索
  • 原文地址:https://www.cnblogs.com/ouyangping/p/7396700.html
Copyright © 2011-2022 走看看