java 回调函数例子,其原理,与代理模式的区别

java 回调函数例子,及其原理,与代理模式的区别

回调函数

  应用程序(application program)会时常通过API调用库里所预先备好的函数。但是有些库函数(library function)却要求应用先传给它一个函数,好在合适的时候调用,以完成目标任务。这个被传入的、后又被调用的函数就称为回调函数(callback function)。
作用: 可以把调用者与被调用者分开。调用者不关心谁是被调用者,所有它需知道的,只是存在一个具有某种特定原型、某些限制条件(如返回值为int)的被调用函数。

例子

一个计算函数运行时间的工具类,正常方法

/**
 * @Auther: cpb
 * @Date: 2019/1/17 16:32
 * @Description:
 */
public class RunningTime {
    /**
     * 一个用来被测试的方法,进行了一个比较耗时的循环
     */
    public   static   void  testMethod(){
        for ( int  i= 0 ; i< 100000000 ; i++){

        }
    }
    /**
     * 一个简单的测试方法执行时间的方法
     */
    public  void testTime(){
        long  begin = System.currentTimeMillis(); //测试起始时间
        testMethod(); //测试方法
        long  end = System.currentTimeMillis(); //测试结束时间
        System.out.println("[use time]:"  + (end - begin)); //打印使用时间
    }

    public static void main(String[] args) {
        RunningTime test=new  RunningTime();
        test.testTime();
    }
}

创建回调函数接口

public interface CallBack {
    //执行回调操作的方法
    void  execute();
}

回调函数

/**
 * @Auther: cpb
 * @Date: 2019/1/17 16:35
 * @Description:
 */
public class Tools {
    /**
     * 测试函数使用时间,通过定义CallBack接口的execute方法
     * @param callBack
     */
    public   void  testTime(CallBack callBack) {
        long  begin = System.currentTimeMillis(); //测试起始时间
        callBack.execute(); ///进行回调操作
        long  end = System.currentTimeMillis(); //测试结束时间
        System.out.println("[use time]:"  + (end - begin)); //打印使用时间
    }

    public   static   void  main(String[] args) {
        Tools tool = new  Tools();
        tool.testTime(new  CallBack(){
            //定义execute方法
            public   void  execute(){
                //这里可以加放一个或多个要测试运行时间的方法
                RunningTime.testMethod();
            }
        });
    }
}

为什么叫回调函数

我们观看一下程序运行的流程,tools->CallBacks->tools,顾为回调函数。

代理模式

//接口
public interface CallBack {
    //执行回调操作的方法
    void  execute();
}
//实现类
public class MyCallBack implements CallBack{
    @Override
    public void execute() {
        MyCallBack.testMethod();
    }
    public   static   void  testMethod(){
        for ( int  i= 0 ; i< 100000000 ; i++){

        }
    }
}

//代理类
public class Proxy implements CallBack {
    private CallBack callBack;

    public Proxy(CallBack callBack){
        this.callBack = callBack;
    }
    @Override
    public void execute() {
        callBack.execute();
    }
}

//调用方法类
public class Tools {
    /**
     * 测试函数使用时间,通过定义CallBack接口的execute方法
     * @param callBack
     */
    public   void  testTime(CallBack callBack) {
        long  begin = System.currentTimeMillis(); //测试起始时间
        callBack.execute(); ///进行回调操作
        long  end = System.currentTimeMillis(); //测试结束时间
        System.out.println("[use time]:"  + (end - begin)); //打印使用时间
    }

    public   static   void  main(String[] args) {
        Tools tool = new Tools();
        //让代理去实现方法去调用方法
        Proxy proxy = new Proxy(new MyCallBack());
        tool.testTime(proxy);
    }
}

代理模式和回调函数的区别

  1. 代理模式需要创建接口实现类,并放入代理类中,隔离性更好,扩展性好
  2. 回调函数不需要创建接口实现类,编写方便。
  • 13
    点赞
  • 60
    收藏
    觉得还不错? 一键收藏
  • 5
    评论
评论 5
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值