查看Java一段程序運行了多長時間(以幾小時幾分幾秒的形式顯示)


我們通常可以用 long ms=System.currentTimeMillis(); 來取得以毫秒為單位起始時間和終止時間,它們的時間差除以一千就知道一段Java程序運行了多少秒,但多少秒並不直觀,比如900秒你要反應一下,說15分就馬上反應過來了。下面提供了計算的函數 和使用示例代碼:

    public static void main(String[] args) {
        long startMs=System.currentTimeMillis();
        
     ... // do something        
long endMs=System.currentTimeMillis(); System.out.println("Time elapsed:"+ms2DHMS(startMs,endMs)); } /** * change seconds to DayHourMinuteSecond format * * @param startMs * @param endMs * @return */ private static String ms2DHMS(long startMs, long endMs) { String retval = null; long secondCount = (endMs - startMs) / 1000; String ms = (endMs - startMs) % 1000 + "ms"; long days = secondCount / (60 * 60 * 24); long hours = (secondCount % (60 * 60 * 24)) / (60 * 60); long minutes = (secondCount % (60 * 60)) / 60; long seconds = secondCount % 60; if (days > 0) { retval = days + "d" + hours + "h" + minutes + "m" + seconds + "s"; } else if (hours > 0) { retval = hours + "h" + minutes + "m" + seconds + "s"; } else if (minutes > 0) { retval = minutes + "m" + seconds + "s"; } else if(seconds > 0) { retval = seconds + "s"; }else { return ms; } return retval + ms; }

輸出示例:

Time elapsed:3m55s872ms

--2020年2月29日--

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM