Java 回调函数

下面使用java回调函数来实现一个测试函数运行时间的工具类:


如果我们要测试一个类的方法的执行时间,通常我们会这样做:

复制代码
public   class  TestObject {  
    /**  
     * 一个用来被测试的方法,进行了一个比较耗时的循环  
     */   
    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) {  
        TestObject test=new  TestObject();  
        test.testTime();  
    }  
}  
复制代码

大家看到了testTime()方法,就只有"//测试方法"是需要改变的,下面我们来做一个函数实现相同功能但更灵活:

首先定一个回调接口:

public   interface  CallBack {  
    //执行回调操作的方法   
    void  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();  
        tool.testTime(new  CallBack(){  
            //定义execute方法   
            public   void  execute(){  
                //这里可以加放一个或多个要测试运行时间的方法   
                TestObject.testMethod();  
            }  
        });  
    }  
      
}  
复制代码

大家看到,testTime()传入定义callback接口的execute()方法就可以实现回调功能

 

本文转自:http://kidult.iteye.com/blog/148982

posted @   似水流云  阅读(297)  评论(0编辑  收藏  举报
编辑推荐:
· AI与.NET技术实操系列:基于图像分类模型对图像进行分类
· go语言实现终端里的倒计时
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
阅读排行:
· 25岁的心里话
· 闲置电脑爆改个人服务器(超详细) #公网映射 #Vmware虚拟网络编辑器
· 零经验选手,Compose 一天开发一款小游戏!
· 因为Apifox不支持离线,我果断选择了Apipost!
· 通过 API 将Deepseek响应流式内容输出到前端
点击右上角即可分享
微信分享提示