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.pswp.cn/news/533057.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/533057.shtml
英文地址,請注明出處:http://en.pswp.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…