Java簡單計(jì)時(shí)的實(shí)現(xiàn)案例(可以用來限時(shí)循環(huán))
在軟件開發(fā)過程中經(jīng)常需要知道程序運(yùn)行的大概時(shí)間,或者需要在規(guī)定時(shí)間內(nèi)取數(shù)據(jù),這是可以使用下面的方法獲取時(shí)間段,還可以用在限時(shí)循環(huán)
方法一:
/** 獲取當(dāng)前系統(tǒng)時(shí)間*/ long startTime = System.currentTimeMillis(); /** 程序運(yùn)行 processRun();*/ /** 獲取當(dāng)前的系統(tǒng)時(shí)間,與初始時(shí)間相減就是程序運(yùn)行的毫秒數(shù),除以1000就是秒數(shù)*/ long endTime = System.currentTimeMillis(); long usedTime = (endTime-startTime)/1000;
方法二:
//初始化變量 Date before=new Date(); Date now=new Date(); //定時(shí)循環(huán) while(t<=10//循環(huán)時(shí)間){ // 計(jì)算循環(huán)總時(shí)長 now = new Date(); // 現(xiàn)在的時(shí)間減去開始的時(shí)間可以計(jì)算出來使用的時(shí)間 t = (now.getTime() - before.getTime())/1000; //循環(huán)內(nèi)容 }
補(bǔ)充知識:Java中更精確的計(jì)時(shí)代碼
我們一般的java運(yùn)輸計(jì)時(shí)代碼是
long begintime = System.currentTimeMillis(); //運(yùn)算代碼 long endtinme=System.currentTimeMillis(); long costTime = (endtime - begintime);
但是,如果運(yùn)算時(shí)間很短的時(shí)候,這個(gè)一個(gè)是現(xiàn)在機(jī)器太厲害,還有由于.currentTimeMillis()是1970年1月1日到現(xiàn)在的毫秒數(shù),估計(jì)應(yīng)該把很多小數(shù)位省略了,沒看過代碼,猜的,呵呵。結(jié)果一般是0,無法顯示算法消耗時(shí)間,這個(gè)時(shí)候可以用nanoTime(),納秒。
long begintime = System.nanoTime(); //運(yùn)算代碼 long endtime = System.nanoTime(); long costTime = (endtime - begintime)/1000; //要換算為微秒,就除上1000,就可以
以上這篇Java簡單計(jì)時(shí)的實(shí)現(xiàn)案例(可以用來限時(shí)循環(huán))就是小編分享給大家的全部內(nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
IDEA下載并大學(xué)生edu郵箱認(rèn)證免費(fèi)使用教程(圖文)
這篇文章主要介紹了IDEA下載并大學(xué)生edu郵箱認(rèn)證免費(fèi)使用教程(圖文),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-07-07SpringBoot中Bean拷貝及工具類封裝的實(shí)現(xiàn)
本文主要介紹了SpringBoot中Bean拷貝及工具類封裝的實(shí)現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2023-05-05Java 函數(shù)式編程要點(diǎn)總結(jié)
函數(shù)式編程并不是Java新提出的概念,其與指令編程相比,強(qiáng)調(diào)函數(shù)的計(jì)算比指令的計(jì)算更重要;與過程化編程相比,其中函數(shù)的計(jì)算可以隨時(shí)調(diào)用。Java8新引入函數(shù)式編程方式,大大的提高了編碼效率。本文將對涉及的對象等進(jìn)行統(tǒng)一的學(xué)習(xí)及記錄。2021-06-06關(guān)于idea2020.3升級lombok不能使用的問題
這篇文章主要介紹了關(guān)于idea2020.3升級lombok不能使用的問題,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-12-12maven插件assembly使用及springboot啟動(dòng)腳本start.sh和停止腳本 stop.sh
這篇文章主要介紹了maven插件assembly使用及springboot啟動(dòng)腳本start.sh和停止腳本 stop.sh的相關(guān)資料,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-08-08java、php、C#、asp實(shí)現(xiàn)短信群發(fā)功能的方法
這篇文章主要介紹了java、php、C#、asp實(shí)現(xiàn)短信群發(fā)功能的方法,以實(shí)例形式較為詳細(xì)的分析了java及php、C#、asp、VB.NET等調(diào)用短信發(fā)送接口進(jìn)行短信發(fā)送的功能,需要的朋友可以參考下2015-02-02