Java中回调函数的使用
2015-08-31 14:54
549 查看
计算一个方法执行的时间:
通常我们会这样做:
大家看到了testTime()方法,就只有"//测试方法"是需要改变的,下面我们来做一个函数实现相同功能但更灵活:
首先定一个回调接口:
再写一个工具类:
下面的是我们要测试的两个方法,执行需要的时间:
测试类:
说明:1、calculationTime()传入定义callback接口的execute()方法就可以实现回调功能
2、只定义接口,不具体实现,在调用的时候,匿名实现接口。
通常我们会这样做:
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 calculationTime(CallBack callBack) { long begin = System.currentTimeMillis(); callBack.execute(); long end = System.currentTimeMillis(); System.out.println("开始时间:" + begin); System.out.println("结束时间:" + end); System.out.println("耗时:" + (end - begin)); } }
下面的是我们要测试的两个方法,执行需要的时间:
public class MyObject { /** * 一个用来被测试的方法,进行了一个比较耗时的循环 */ public static void method1() { for (int i = 0; i < 1000; i++) { System.out.println(i); } } public static void method2() { for (int i = 0; i < 10000; i++) { System.out.println(i); } } }
测试类:
public class Main { public static void main(String[] args) { Tools tools = new Tools(); tools.calculationTime(new CallBack() { @Override public void execute() { MyObject.method1(); } }); } }
说明:1、calculationTime()传入定义callback接口的execute()方法就可以实现回调功能
2、只定义接口,不具体实现,在调用的时候,匿名实现接口。
相关文章推荐
- Spring注解@Component、@Repository、@Service、@Controller区别
- java sound
- 使用内省完成JavaBean到集合的封装
- JAVA泛型? T K V E等代表的意思
- 精选30道Java笔试题解答
- 安卓文件安全删除问题 --- java.io.IOException: open failed: EBUSY (Device or resource busy) (System.err)
- Java:String和Date、Timestamp之间的转换
- Java base64加密
- SpringMVC源码剖析(五)-消息转换器
- java类的初始化顺序
- spring错误-在spring里面找不到org.springframework.cache.ehcache.EhCacheManagerFactoryBean
- Java的注释说明
- spring学习笔记---Jackson的使用和定制
- 约瑟夫环问题
- SpringMVC源码剖析(三)- DispatcherServlet的初始化流
- mac os下eclipse修改svn的用户名和密码 mac svn checkout 报 403 Forbidden 错误的处理方法
- Eclipse工具使用技巧总结
- Java构造和解析Json数据的两种方法详解一
- springmvc后台数据验证
- myeclipse中web项目编译错误解决办法。