Как точно рассчитать время, необходимое программе Java для записи или чтения файла? - PullRequest
5 голосов
/ 08 апреля 2009

Как точно вычислить время, необходимое программе Java для записи или чтения количества байтов из / в файл?

Очень важно, чтобы время точно измерялось. (Время должно быть рассчитано самой программой).

Ответы [ 5 ]

16 голосов
/ 08 апреля 2009

Стандартная идиома:

long startTime = System.nanoTime();
doSomething();
long elapsedTime = System.nanoTime() - startTime;
5 голосов
/ 08 апреля 2009

не проверено, но что-то вроде:

long delta = System.nanoTime();
try {
    // do your stuff
} finally {
    delta = System.nanoTime() - delta;
}
2 голосов
/ 09 апреля 2009

То, как я бы это сделал, это просто запустить его несколько раз. Например, если вы запустите его 1000 раз и синхронизируете его, это даст вам миллисекунды. Запустите его 1 000 000 раз, и он даст вам микросекунды.

Если вы также хотите выяснить, почему это занимает столько времени, сколько нужно, вы можете просто приостановить его несколько раз (например, 10) во время работы, и это скажет вам, что он делает и почему.

2 голосов
/ 08 апреля 2009

Здесь приведен пример кода:

http://www.goldb.org/stopwatchjava.html

/*
    Copyright (c) 2005, Corey Goldberg

    StopWatch.java is free software; you can redistribute it and/or modify
    it under the terms of the GNU General Public License as published by
    the Free Software Foundation; either version 2 of the License, or
    (at your option) any later version.
*/


public class StopWatch {

    private long startTime = 0;
    private long stopTime = 0;
    private boolean running = false;


    public void start() {
        this.startTime = System.currentTimeMillis();
        this.running = true;
    }


    public void stop() {
        this.stopTime = System.currentTimeMillis();
        this.running = false;
    }


    //elaspsed time in milliseconds
    public long getElapsedTime() {
        long elapsed;
        if (running) {
             elapsed = (System.currentTimeMillis() - startTime);
        }
        else {
            elapsed = (stopTime - startTime);
        }
        return elapsed;
    }


    //elaspsed time in seconds
    public long getElapsedTimeSecs() {
        long elapsed;
        if (running) {
            elapsed = ((System.currentTimeMillis() - startTime) / 1000);
        }
        else {
            elapsed = ((stopTime - startTime) / 1000);
        }
        return elapsed;
    }




    //sample usage
    public static void main(String[] args) {
        StopWatch s = new StopWatch();
        s.start();
        //code you want to time goes here
        s.stop();
        System.out.println("elapsed time in milliseconds: " + s.getElapsedTime());
    }
}
1 голос
/ 09 апреля 2009

Проблема метода get System.xxx заключается в том, что самому методу требуется несколько миллисекунд для вычисления. Обычно «общепринятый» способ сделать это - выполнить тест несколько десятков тысяч раз и вычислить среднее значение этого.

Кроме того, в зависимости от вашей ОС есть то, что называется временной гранулярностью (пример для Windows) Это наименьшее количество времени, которое ваша ОС может вычислить. В некоторых ОС - миллисекунда, в других - наносекунда. Это может или не может иметь отношение к вашему делу.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...