java 类确定运行时间_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://www.mzph.cn/news/533057.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

java socket调用接口_Java中socket接口调用

最近一个项目中接口通讯这一块主要是调用银联系统的socket接口&#xff0c;我方是客户端&#xff0c;即发送请求接收返回报文的一方。在贴代码之前&#xff0c;还是要了解一下关于socket的基础知识。Socket的基本概念1&#xff0e;建立连接当需要建立网络连接时&#xff0c;必须…

protobuf java 编译_Maven项目中,编译proto文件成Java类

新建Maven项目新建一个 Maven 项目&#xff1a;pom定义了最小的maven2元素&#xff0c;即&#xff1a;groupId,artifactId,version。 groupId:项目或者组织的唯一标志&#xff0c;并且配置时生成的路径也是由此生成&#xff0c;如org.codehaus.mojo生成的相对路径为&#xff1a…

java 结构体数组初始化_C数组结构体联合体快速初始化

背景C89标准规定初始化语句的元素以固定顺序出现&#xff0c;该顺序即待初始化数组或结构体元素的定义顺序。C99标准新增指定初始化(Designated Initializer)&#xff0c;即可按照任意顺序对数组某些元素或结构体某些成员进行选择性初始化&#xff0c;只需指明它们所对应的数组…

java override 访问权限_java基础之——访问修饰符(private/default/protected/public)

1. 访问修饰符介绍java中的访问修饰符包含了四种&#xff1a;private、default(没有对应的保留字)、protected和public。它们的含义如下&#xff1a;private&#xff1a;如果一个元素声明为private&#xff0c;那么只有同一个类下的元素才可以访问它。default&#xff1a;如果一…

python中scrapy可以爬取多少数据_python中scrapy框架爬取携程景点数据

———————————————————————————————[版权申明&#xff1a;本文系作者原创&#xff0c;转载请注明出处]文章出处&#xff1a;https://blog.csdn.net/sdksdk0/article/details/82381198作者&#xff1a;朱培 ID&#xff1a;sdksdk0——————…

python灰色关联度分析代码_灰色关联分析法步骤 - osc_uwnmtz9n的个人空间 - OSCHINA - 中文开源技术交流社区...

https://wenku.baidu.com/view/dc356290af1ffc4fff47ac0d.html?rec_flagdefault&sxts1538121950212利用灰色关联分析的步骤是&#xff1a;1&#xff0e;根据分析目的确定分析指标体系&#xff0c;收集分析数据。设n个数据序列形成如下矩阵&#xff1a;其中m为指标的个数&a…

aio 系统原理 Java_Java新一代网络编程模型AIO原理及Linux系统AIO介绍

从JDK 7版本开始&#xff0c;Java新加入的文件和网络io特性称为nio2(new io 2, 因为jdk1.4中已经有过一个nio了)&#xff0c;包含了众多性能和功能上的改进&#xff0c;其中最重要的部分&#xff0c;就是对异步io的支持&#xff0c;称为Java AIO(asynchronous IO)。因为AIO的实…

centos mysql 5.5 art_Linux CentOS6.5下编译安装MySQL 5.5.51''''

一、编译安装MySQL前的准备工作安装编译源码所需的工具和库yum install gcc gcc-c ncurses-devel perl安装cmake&#xff0c;从http://www.cmake.org下载源码并编译安装wget http://www.cmake.org/files/v2.8/cmake-2.8.10.2.tar.gztar -xzvf cmake-2.8.10.2.tar.gzcd cmake-2.…

java修改默认字符编码_设置默认的Java字符编码?

如何以编程方式正确设置JVM(1.5.x)使用​​的默认字符编码&#xff1f;我已经读过-Dfile.encoding 以前是以往的方式去为旧的JVM …我没有那么奢侈的原因&#xff0c;我不会进入。我努力了&#xff1a;System.setProperty("file.encoding", "UTF-8");并且属…

java api 第一个类是_JAVA常用API:String 类的常用方法

字符串是一个对象&#xff0c;有很多方法可以使用1. length();返回字符串的长度String str "abcd";int len str.length();2. isEmpty(); 仅当当length()为0时返回true,否则返回falseboolean b str.isEmpty();3. getBytes();返回字符串中每个字符的ASCII码(使用平台…

关于java内容_关于java一些概念性的内容

PO&#xff1a;persistant object持久对象最形象的理解就是一个PO就是数据库中的一条记录。好处是可以把一条记录作为一个对象处理&#xff0c;可以方便的转为其它对象。--------------------------------------------------------------------------------BO&#xff1a;busin…

java订单类_基于Java创建一个订单类代码实例

这篇文章主要介绍了基于Java创建一个订单类代码实例,文中通过示例代码介绍的非常详细&#xff0c;对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下需求描述定义一个类&#xff0c;描述订单信息订单id订单所属用户(用户对象)订单所包含的商品(不定数量个商品对…

java请假审批怎么实现_java实现请假时间判断

笔记:需求分析:每周上班6天夏季早上8:30-12:00下午14:00-17:30冬季早上8:30-12:00下午14:30-18:00请假最低为半天按照上午8:00-12:00,下午14:00-18:00计算,包括了夏季和冬季时间,规律分布如下public String getDouble(HttpServletRequest request) throws ParseException {//参…

mariadb mysql 5.6_MySQL / MariaDB 5.5 升级到 MySQL 5.6

RHEL 及 CentOS 7 默认的资库系统是 MariaDB 5.5 (等同 MySQL 5.5), 虽然现时 MySQL 最新版是 5.7, 但一般上升级都建议一级一级上, 而 MySQL 5.6 比 5.5 也提高了效能及提供更多功能, 以下是在 RHEL 及 CentOS 从原来的 MySQL 5.5 或 MariaDB 5.5, 升级到 MySQL 5.6 的步骤。1…

iText报表Java_(例)Java生成PDF报表 iText

// 导入&#xff29;&#xff2f;库类import java.io.FileInputStream;import java.io.FileNotFoundException;import java.io.FileOutputStream;import java.io.IOException;import java.io.InputStream;import java.util.ArrayList;// 导入 &#xff30;&#xff2f;&#x…

mysql update修改数据_MySQL UPDATE:修改数据(更新数据)

在 MySQL 中&#xff0c;可以使用 UPDATE 语句来修改、更新一个或多个表的数据。UPDATE 语句的基本语法使用 UPDATE 语句修改单个表&#xff0c;语法格式为&#xff1a;UPDATE SET 字段 1值 1 [,字段 2值 2… ] [WHERE 子句 ][ORDER BY 子句] [LIMIT 子句]语法说明如下&#xf…

java堆内存 数据结构_JAVA内存区域

首先解释下内存溢出和内存泄露之间的区别&#xff0c;为后面的学习做些铺垫&#xff1a;1、内存溢出和内存泄露的区别和联系内存溢出 out of memory&#xff1a;是指程序申请内存时&#xff0c;没有足够的内存供申请者使用&#xff0c;或者说&#xff0c;给了你一块存储int类型…

java jsp的指令_[javaEE] jsp的指令

jsp的指令&#xff1a;jsp的指令(directive)是为jsp引擎而设计的&#xff0c;他们并不直接产生任何可见输出&#xff0c;而是告诉引擎如何处理jsp页面中的其他部分页面头部的page指令pageEncoding"utf-8"%>配置错误页面&#xff1a;web.xml500/500.jsp404/404.jsp…

JAVA不能满屏_java – 全屏幕视频,不拉伸视频

像这样&#xff0c;你可以自己设置视频的属性。使用SurfaceView(给你更多的视图控制)&#xff0c;将其设置为fill_parent以匹配整个屏幕android:orientation"vertical"android:layout_width"match_parent"android:layout_height"fill_parent">…

java异常标记_java.lang.RuntimeException:错误:0D0680A8:asn1编码例程:ASN1_CHECK_TLEN:错误的标记...

我收到此错误(在标题中).我不确定为什么,请帮忙.代码如下&#xff1a;public static String decryptRSA(Context mContext, byte[] message) throws Exception {InputStream in mContext.getResources().openRawResource(R.raw.publicrsakey);X509EncodedKeySpec x509EncodedK…