有時候為了排查性能問題,需要記錄完成某個操作需要的時間,我們可以使用System類的currentTimeMillis()方法來返回當前的毫秒數,並保存到一個變量中,在方法執行完畢后再次調用 System的currentTimeMillis()方法,並計算兩次調用之間的差值,就是方法執行所消耗的毫秒數。
如下代碼示例:
- public class Main {
- /**
- * 計算兩個時間點直接逝去的毫秒數
- *
- */
- public void computeAndDisplayElapsedTime() {
- long startTime = System.currentTimeMillis();
- for (int i = 0; i < 10; i++) {
- try {
- Thread.sleep(60);
- } catch (InterruptedException ex) {
- ex.printStackTrace();
- }
- }
- long endTime = System.currentTimeMillis();
- float seconds = (endTime - startTime) / 1000F;
- System.out.println(Float.toString(seconds) + " seconds.");
- }
- /**
- * 啟動程序
- */
- public static void main(String[] args) {
- new Main().computeAndDisplayElapsedTime();
- }
- }
輸出結果類似:
```out
0.609 seconds.