Java使用System.currentTimeMillis()方法計算程序運行時間的示例代碼
Java 中提供的 System.currentTimeMillis() 方法用于獲取當前的計算機時間,時間的表達格式為當前計算機時間和 GMT 時間(格林威治時間)1970年1月1號0時0分0秒所差的毫秒數。
System.currentTimeMillis() 方法的返回類型為 long ,表示毫秒為單位的當前時間。
在開發(fā)過程中,通常很多人都習慣使用 new Date() 來獲取當前時間。new Date() 所做的事情其實就是調用了 System.currentTimeMillis()方法。如果僅僅是需要或者毫秒數,那么完全可以使用 System.currentTimeMillis() 去代替 new Date(),效率上會高一點。
【示例】計算 String 類型與 StringBuilder 類型拼接字符串的耗時情況。
/** * Java使用System.currentTimeMillis()方法計算程序運行時間 * @author pan_junbiao **/ public class CurrentTimeTest { /** * 使用String類型拼接字符串耗時 */ public static void testString() { String s = "Hello"; String s1 = "World"; long start = System.currentTimeMillis(); for(int i=0; i<10000; i++) { s+=s1; } long end = System.currentTimeMillis(); long runTime = (end - start); System.out.println("使用String類型拼接字符串耗時:" + runTime + "毫秒"); } /** * 使用StringBuilder類型拼接字符串耗時 */ public static void testStringBuilder() { StringBuilder s = new StringBuilder("Hello"); String s1 = "World"; long start = System.currentTimeMillis(); for(int i=0; i<10000; i++) { s.append(s1); } long end = System.currentTimeMillis(); long runTime = (end - start); System.out.println("使用StringBuilder類型拼接字符串耗時:" + runTime + "毫秒"); } public static void main(String[] args) { testString(); testStringBuilder(); } }
運行結果:
知識點補充:
從上圖的運行結果可以看出,在拼接字符串過程中,使用 StringBuilder 對象,而不使用 String 對象。這是因為 String 是不可變的對象,在每一次改變字符串時都會創(chuàng)建一個新的 String 對象;而 StringBuilder 則是可變的字符序列,類似于 String 的字符串緩沖區(qū)。所以,在字符串經常修改的地方使用 StringBuilder ,其效率將高于 String。
在這方面運行速度快慢為:StringBuilder > StringBuffer > String。
線程安全上,StringBuilder 是線程不安全的,而 StringBuffer 是線程安全的。
到此這篇關于Java使用System.currentTimeMillis()方法計算程序運行時間的文章就介紹到這了,更多相關Java計算程序運行時間內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
Java開發(fā)之spring security實現基于MongoDB的認證功能
這篇文章主要介紹了Java開發(fā)之spring security實現基于MongoDB的認證功能,結合實例形式分析了spring security在非JDBC環(huán)境下的自定義認證服務實現技巧,需要的朋友可以參考下2017-11-11使用Java編寫控制JDBC連接、執(zhí)行及關閉的工具類
這篇文章主要介紹了如何使用Java來編寫控制JDBC連接、執(zhí)行及關閉的程序,包括一個針對各種數據庫通用的釋放資源的工具類的寫法,需要的朋友可以參考下2016-03-03JDBC中Statement和Preparement的使用講解
今天小編就為大家分享一篇關于JDBC中Statement和Preparement的使用講解,小編覺得內容挺不錯的,現在分享給大家,具有很好的參考價值,需要的朋友一起跟隨小編來看看吧2019-01-01一個例子帶你看懂Java中synchronized關鍵字到底怎么用
synchronized是Java里的一個關鍵字,起到的一個效果是"監(jiān)視器鎖",它的功能就是保證操作的原子性,同時禁止指令重排序和保證內存的可見性,下面這篇文章主要給大家介紹了關于如何通過一個例子帶你看懂Java中synchronized關鍵字到底怎么用的相關資料,需要的朋友可以參考下2022-10-10