Java項目計算程式執行時間方法

来源:https://www.cnblogs.com/damudaran/p/18022411
-Advertisement-
Play Games

一、總結 1.1、使用System.currentTimeMillis();計算程式執行毫秒數 // 開始時間1 long startTime1 = System.currentTimeMillis(); Thread.sleep(100); // 結束時間1 long endTime1 = Sys ...


一、總結

1.1、使用System.currentTimeMillis();計算程式執行毫秒數

		// 開始時間1
		long startTime1 = System.currentTimeMillis();
		Thread.sleep(100);
		// 結束時間1
		long endTime1 = System.currentTimeMillis();

		// 開始時間2
		long startTime2 = System.currentTimeMillis();
		Thread.sleep(200);
		// 結束時間2
		long endTime2 = System.currentTimeMillis();
		System.out.println("邏輯1執行時間:"+ (endTime1 - startTime1));
		System.out.println("邏輯2執行時間:"+ (endTime2 -startTime2));

1.2、使用org.springframework.util包下的一個工具類StopWatch計算執行時間

		StopWatch testTask = new StopWatch("TestTask");
		// 記錄開始時間點
		testTask.start("task1");
		Thread.sleep(100);
		// 記錄結束時間點
		testTask.stop();
		// 記錄開始時間點
		testTask.start("task2");
		Thread.sleep(200);
		// 記錄結束時間點
		testTask.stop();
		// 輸出執行時間
		System.out.println("==任務執行時間==");
		System.out.println(testTask.prettyPrint());
		System.out.println("執行任務的毫秒數:"+testTask.getTotalTimeMillis());

1.3兩個案例的完整代碼、執行結果

package time.stopwatch;

import org.springframework.util.StopWatch;

public class StopWatchTest {
		public static void main(String[] args) throws InterruptedException {
		// 計算執行時間
		calculateExecuteTime1();
		// 計算執行時間
		calculateExecuteTime2();
	}

	public static void calculateExecuteTime1() throws InterruptedException {
		// 開始時間1
		long startTime1 = System.currentTimeMillis();
		Thread.sleep(100);
		// 結束時間1
		long endTime1 = System.currentTimeMillis();

		// 開始時間2
		long startTime2 = System.currentTimeMillis();
		Thread.sleep(200);
		// 結束時間2
		long endTime2 = System.currentTimeMillis();
		System.out.println("邏輯1執行時間:"+ (endTime1 - startTime1));
		System.out.println("邏輯2執行時間:"+ (endTime2 -startTime2));
	}

	public static void calculateExecuteTime2() throws InterruptedException {
		StopWatch testTask = new StopWatch("TestTask");
		// 記錄開始時間點
		testTask.start("task1");
		Thread.sleep(100);
		// 記錄結束時間點
		testTask.stop();
		// 記錄開始時間點
		testTask.start("task2");
		Thread.sleep(200);
		// 記錄結束時間點
		testTask.stop();
		// 輸出執行時間
		System.out.println("==任務執行時間==");
		System.out.println(testTask.prettyPrint());
		System.out.println("執行任務的毫秒數:"+testTask.getTotalTimeMillis());
	}
}

執行結果:

邏輯1執行時間:109
邏輯2執行時間:203
==任務執行時間==
StopWatch 'TestTask': running time = 319076700 ns
---------------------------------------------
ns         %     Task name
---------------------------------------------
114748000  036%  task1
204328700  064%  task2

執行任務的毫秒數:319

1.4 StopWatch優缺點:

優點:
1、spring自帶工具類,可直接使用
2、代碼實現簡單,使用更簡單
3、統一歸納,展示每項任務耗時與占用總時間的百分比,展示結果直觀
4、性能消耗相對較小,並且最大程度的保證了start與stop之間的時間記錄的準確性
5、可在start時直接指定任務名字,從而更加直觀的顯示記錄結果
缺點:
1、一個StopWatch實例一次只能開啟一個task,不能同時start多個task,並且在該task未stop之前不能start一個新的task,必須在該task stop之後才能開啟新的task,若要一次開啟多個,需要new不同的StopWatch實例
2、代碼侵入式使用,需要改動多處代碼

1.5、spring中StopWatch源碼實現如下:

import java.text.NumberFormat;
import java.util.LinkedList;
import java.util.List;

public class StopWatch {
	private final String id;
	private boolean keepTaskList = true;
	private final List<TaskInfo> taskList = new LinkedList();
	private long startTimeMillis;
	private boolean running;
	private String currentTaskName;
	private StopWatch.TaskInfo lastTaskInfo;
	private int taskCount;
	private long totalTimeMillis;

	public StopWatch() {
		this.id = "";
	}

	public StopWatch(String id) {
		this.id = id;
	}

	public void setKeepTaskList(boolean keepTaskList) {
		this.keepTaskList = keepTaskList;
	}

	public void start() throws IllegalStateException {
		this.start("");
	}

	public void start(String taskName) throws IllegalStateException {
		if (this.running) {
			throw new IllegalStateException("Can't start StopWatch: it's already running");
		} else {
			this.startTimeMillis = System.currentTimeMillis();
			this.running = true;
			this.currentTaskName = taskName;
		}
	}

	public void stop() throws IllegalStateException {
		if (!this.running) {
			throw new IllegalStateException("Can't stop StopWatch: it's not running");
		} else {
			long lastTime = System.currentTimeMillis() - this.startTimeMillis;
			this.totalTimeMillis += lastTime;
			this.lastTaskInfo = new StopWatch.TaskInfo(this.currentTaskName, lastTime);
			if (this.keepTaskList) {
				this.taskList.add(this.lastTaskInfo);
			}

			++this.taskCount;
			this.running = false;
			this.currentTaskName = null;
		}
	}

	public boolean isRunning() {
		return this.running;
	}

	public long getLastTaskTimeMillis() throws IllegalStateException {
		if (this.lastTaskInfo == null) {
			throw new IllegalStateException("No tasks run: can't get last task interval");
		} else {
			return this.lastTaskInfo.getTimeMillis();
		}
	}

	public String getLastTaskName() throws IllegalStateException {
		if (this.lastTaskInfo == null) {
			throw new IllegalStateException("No tasks run: can't get last task name");
		} else {
			return this.lastTaskInfo.getTaskName();
		}
	}

	public StopWatch.TaskInfo getLastTaskInfo() throws IllegalStateException {
		if (this.lastTaskInfo == null) {
			throw new IllegalStateException("No tasks run: can't get last task info");
		} else {
			return this.lastTaskInfo;
		}
	}

	public long getTotalTimeMillis() {
		return this.totalTimeMillis;
	}

	public double getTotalTimeSeconds() {
		return (double) this.totalTimeMillis / 1000.0D;
	}

	public int getTaskCount() {
		return this.taskCount;
	}

	public StopWatch.TaskInfo[] getTaskInfo() {
		if (!this.keepTaskList) {
			throw new UnsupportedOperationException("Task info is not being kept!");
		} else {
			return (StopWatch.TaskInfo[]) this.taskList.toArray(new StopWatch.TaskInfo[this.taskList.size()]);
		}
	}

	public String shortSummary() {
		return "StopWatch '" + this.id + "': running time (millis) = " + this.getTotalTimeMillis();
	}

	public String prettyPrint() {
		StringBuilder sb = new StringBuilder(this.shortSummary());
		sb.append('\n');
		if (!this.keepTaskList) {
			sb.append("No task info kept");
		} else {
			sb.append("-----------------------------------------\n");
			sb.append("ms     %     Task name\n");
			sb.append("-----------------------------------------\n");
			NumberFormat nf = NumberFormat.getNumberInstance();
			nf.setMinimumIntegerDigits(5);
			nf.setGroupingUsed(false);
			NumberFormat pf = NumberFormat.getPercentInstance();
			pf.setMinimumIntegerDigits(3);
			pf.setGroupingUsed(false);
			StopWatch.TaskInfo[] var7;
			int var6 = (var7 = this.getTaskInfo()).length;

			for (int var5 = 0; var5 < var6; ++var5) {
				StopWatch.TaskInfo task = var7[var5];
				sb.append(nf.format(task.getTimeMillis())).append("  ");
				sb.append(pf.format(task.getTimeSeconds() / this.getTotalTimeSeconds())).append("  ");
				sb.append(task.getTaskName()).append("\n");
			}
		}

		return sb.toString();
	}

	@Override
	public String toString() {
		StringBuilder sb = new StringBuilder(this.shortSummary());
		if (this.keepTaskList) {
			StopWatch.TaskInfo[] var5;
			int var4 = (var5 = this.getTaskInfo()).length;

			for (int var3 = 0; var3 < var4; ++var3) {
				StopWatch.TaskInfo task = var5[var3];
				sb.append("; [").append(task.getTaskName()).append("] took ").append(task.getTimeMillis());
				long percent = Math.round(100.0D * task.getTimeSeconds() / this.getTotalTimeSeconds());
				sb.append(" = ").append(percent).append("%");
			}
		} else {
			sb.append("; no task info kept");
		}

		return sb.toString();
	}

	public static final class TaskInfo {
		private final String taskName;
		private final long timeMillis;

		TaskInfo(String taskName, long timeMillis) {
			this.taskName = taskName;
			this.timeMillis = timeMillis;
		}

		public String getTaskName() {
			return this.taskName;
		}

		public long getTimeMillis() {
			return this.timeMillis;
		}

		public double getTimeSeconds() {
			return (double) this.timeMillis / 1000.0D;
		}
	}

}

原文摘錄至:https://blog.csdn.net/gxs1688/article/details/87185030
致敬原作者:一個不二,侵刪。


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 痞子衡嵌入式半月刊: 第 92 期 這裡分享嵌入式領域有用有趣的項目/工具以及一些熱點新聞,農曆年分二十四節氣,希望在每個交節之日準時發佈一期。 本期刊是開源項目(GitHub: JayHeng/pzh-mcu-bi-weekly),歡迎提交 issue,投稿或推薦你知道的嵌入式那些事兒。 上期回顧 ...
  • 索引:為了提高數據查詢的效率,就像書的目錄一樣。 索引的常見模型 哈希表 圖中,User2 和 User4 根據身份證號算出來的值都是 N,後面還跟了一個鏈表。假設,這時候你要查 ID_card_n2 對應的名字是什麼,處理步驟就是:首先,將 ID_card_n2 通過哈希函數算出 N;然後,按順序 ...
  • 03 事務隔離 事務:保證一組資料庫操作,要麼全部成功,要麼全部失敗。在 MySQL 中,事務支持是在引擎層實現的。 事務ACID(Atomicity、Consistency、Isolation、Durability,即原子性、一致性、隔離性、持久性)。 建議你儘量不要使用長事務。**** 讀未提交 ...
  • 引言 在實際業務開發中,隨著業務的變化,數據的複雜性和多樣性不斷增加。傳統的關係型資料庫模型在這種情況下會顯得受限,因為它們需要預先定義嚴格的數據模式,並且通常只能存儲具有相同結構的數據。而面對非結構化或半結構化數據的存儲和處理需求,選擇使用非關係型資料庫或者創建子表存儲這些變化的結構可能會變得複雜 ...
  • 在項目開發中需要添加webview,載入內置的html文件,代碼寫完後ios運行沒有問題,運行安卓時報錯,錯誤提示如下: FAILURE: Build failed with an exception. * What went wrong: Execution failed for task ':a ...
  • 玩轉 CMS2 上篇研究了樣式、請求、evn、mock,感覺對效率的提升沒有太明顯作用。 比如某個工作需要2天,現在1天可以幹完,這就是很大的提升。 提高效率的方法有代碼復用、模塊化、低代碼工具。 目前可以考慮從代碼復用方面下手,即使最低級的代碼複製也可以。 要快速提高效率,需要對本地項目中的一些關 ...
  • 這裡給大家分享我在網上總結出來的一些知識,希望對大家有所幫助 ref 和 reactive 是 Vue3 中實現響應式數據的核心 API。ref 用於包裝基本數據類型,而 reactive 用於處理對象和數組。儘管 reactive 似乎更適合處理對象,但 Vue3 官方文檔更推薦使用 ref。 我 ...
  • 簡介 簡單工廠模式又稱為靜態工廠模式,屬於創建型模式,但不屬於GOF23設計模式。由一個工廠對象決定創建出哪一種產品類的實例。簡單工廠模式的實質是由一個工廠類根據傳入的參數,動態決定應該創建哪一個產品類。 簡單工廠適用場景:工廠類負責創建的對象比較少;客戶端只需要知道傳入工廠類的參數,對於如何創建對 ...
一周排行
    -Advertisement-
    Play Games
  • 最近做項目過程中,使用到了海康相機,官方只提供了C/C++的SDK,沒有搜尋到一個合適的封裝了的C#庫,故自己動手,簡單的封裝了一下,方便大家也方便自己使用和二次開發 ...
  • 前言 MediatR 是 .NET 下的一個實現消息傳遞的庫,輕量級、簡潔高效,用於實現進程內的消息傳遞機制。它基於中介者設計模式,支持請求/響應、命令、查詢、通知和事件等多種消息傳遞模式。通過泛型支持,MediatR 可以智能地調度不同類型的消息,非常適合用於領域事件處理。 在本文中,將通過一個簡 ...
  • 前言 今天給大家推薦一個超實用的開源項目《.NET 7 + Vue 許可權管理系統 小白快速上手》,DncZeus的願景就是做一個.NET 領域小白也能上手的簡易、通用的後臺許可權管理模板系統基礎框架。 不管你是技術小白還是技術大佬或者是不懂前端Vue 的新手,這個項目可以快速上手讓我們從0到1,搭建自 ...
  • 第1章:WPF概述 本章目標 瞭解Windows圖形演化 瞭解WPF高級API 瞭解解析度無關性概念 瞭解WPF體繫結構 瞭解WPF 4.5 WPF概述 ​ 歡迎使用 Windows Presentation Foundation (WPF) 桌面指南,這是一個與解析度無關的 UI 框架,使用基於矢 ...
  • 在日常開發中,並不是所有的功能都是用戶可見的,還在一些背後默默支持的程式,這些程式通常以服務的形式出現,統稱為輔助角色服務。今天以一個簡單的小例子,簡述基於.NET開發輔助角色服務的相關內容,僅供學習分享使用,如有不足之處,還請指正。 ...
  • 第3章:佈局 本章目標 理解佈局的原則 理解佈局的過程 理解佈局的容器 掌握各類佈局容器的運用 理解 WPF 中的佈局 WPF 佈局原則 ​ WPF 視窗只能包含單個元素。為在WPF 視窗中放置多個元素並創建更貼近實用的用戶男面,需要在視窗上放置一個容器,然後在這個容器中添加其他元素。造成這一限制的 ...
  • 前言 在平時項目開發中,定時任務調度是一項重要的功能,廣泛應用於後臺作業、計劃任務和自動化腳本等模塊。 FreeScheduler 是一款輕量級且功能強大的定時任務調度庫,它支持臨時的延時任務和重覆迴圈任務(可持久化),能夠按秒、每天/每周/每月固定時間或自定義間隔執行(CRON 表達式)。 此外 ...
  • 目錄Blazor 組件基礎路由導航參數組件參數路由參數生命周期事件狀態更改組件事件 Blazor 組件 基礎 新建一個項目命名為 MyComponents ,項目模板的交互類型選 Auto ,其它保持預設選項: 客戶端組件 (Auto/WebAssembly): 最終解決方案裡面會有兩個項目:伺服器 ...
  • 先看一下效果吧: isChecked = false 的時候的效果 isChecked = true 的時候的效果 然後我們來實現一下這個效果吧 第一步:創建一個空的wpf項目; 第二步:在項目裡面添加一個checkbox <Grid> <CheckBox HorizontalAlignment=" ...
  • 在編寫上位機軟體時,需要經常處理命令拼接與其他設備進行通信,通常對不同的命令封裝成不同的方法,擴展稍許麻煩。 本次擬以特性方式實現,以兼顧維護性與擴展性。 思想: 一種命令對應一個類,其類中的各個屬性對應各個命令段,通過特性的方式,實現其在這包數據命令中的位置、大端或小端及其轉換為對應的目標類型; ...