首页 › 程序设计 › java

java回调函数实例:实现一个测试函数运行时间的工具类

泡在网上的日子 / 文 发表于2012-08-19 23:33 次阅读 回调函数

下面使用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()方法就可以实现回调功能

收藏 赞 (1) 踩 (0)
上一篇:JAVA中的回调函数
在以前的JAVA学习过程当中,不太注意理论知识的学习,所以在阅读thinking in java的时候,就没有太注意其中关于回调函数的介绍。今天,在阅读一段关于网络信使的源代码时,发现了有关回调函数的使用,对他产生了研究的兴趣,不过该源代码中关于回调函数的介
下一篇:Java回调函数使用
所谓回调,就是客户程序CLIENT调用服务程序SERVER中的某个函数SA,然后SERVER又在某个时候反过来调用CLIENT中的某个函数CB,对于CLIENT来说,这个CB便叫做回调函数。例如Win32下的窗口过程函数就是一个典型的回调函数。