Как измерить промежуток времени в секундах, используя System.currentTimeMillis ()? - PullRequest
45 голосов
/ 11 июня 2011

Как конвертировать System.currentTimeMillis(); в секунды?

long start6=System.currentTimeMillis();
System.out.println(counter.countPrimes(100000000)+" for "+start6);

Консоль показывает мне 5761455 for 1307816001290. Я не могу прочитать, сколько это секунд.

Любая помощь?

Ответы [ 9 ]

73 голосов
/ 12 июня 2011

TimeUnit

Используйте TimeUnit enum , встроенный в Java 5 и более поздние версии.

long timeMillis = System.currentTimeMillis();
long timeSeconds = TimeUnit.MILLISECONDS.toSeconds(timeMillis);
63 голосов
/ 11 июня 2011
long start = System.currentTimeMillis();
counter.countPrimes(1000000);
long end = System.currentTimeMillis();

System.out.println("Took : " + ((end - start) / 1000));

ОБНОВЛЕНИЕ

Еще более точное решение будет:

final long start = System.nanoTime();
counter.countPrimes(1000000);
final long end = System.nanoTime();

System.out.println("Took: " + ((end - start) / 1000000) + "ms");
System.out.println("Took: " + (end - start)/ 1000000000 + " seconds");
15 голосов
/ 11 июня 2011

вроде так:

(int)(milliseconds / 1000)
8 голосов
/ 11 июня 2011

Из вашего кода может показаться, что вы пытаетесь измерить, сколько времени заняло вычисление (в отличие от попытки выяснить, каково текущее время).

В этом случае вам нужно вызвать currentTimeMillis до и после вычисления, взять разницу и разделить результат на 1000, чтобы преобразовать миллисекунды в секунды.

3 голосов
/ 12 июня 2011

Я написал следующий код в моем последнем задании, оно может вам помочь:

// A method that converts the nano-seconds to Seconds-Minutes-Hours form
private static String formatTime(long nanoSeconds)
{
    int hours, minutes, remainder, totalSecondsNoFraction;
    double totalSeconds, seconds;


    // Calculating hours, minutes and seconds
    totalSeconds = (double) nanoSeconds / 1000000000.0;
    String s = Double.toString(totalSeconds);
    String [] arr = s.split("\\.");
    totalSecondsNoFraction = Integer.parseInt(arr[0]);
    hours = totalSecondsNoFraction / 3600;
    remainder = totalSecondsNoFraction % 3600;
    minutes = remainder / 60;
    seconds = remainder % 60;
    if(arr[1].contains("E")) seconds = Double.parseDouble("." + arr[1]);
    else seconds += Double.parseDouble("." + arr[1]);


    // Formatting the string that conatins hours, minutes and seconds
    StringBuilder result = new StringBuilder(".");
    String sep = "", nextSep = " and ";
    if(seconds > 0)
    {
        result.insert(0, " seconds").insert(0, seconds);
        sep = nextSep;
        nextSep = ", ";
    }
    if(minutes > 0)
    {
        if(minutes > 1) result.insert(0, sep).insert(0, " minutes").insert(0, minutes);
        else result.insert(0, sep).insert(0, " minute").insert(0, minutes);
        sep = nextSep;
        nextSep = ", ";
    }
    if(hours > 0)
    {
        if(hours > 1) result.insert(0, sep).insert(0, " hours").insert(0, hours);
        else result.insert(0, sep).insert(0, " hour").insert(0, hours);
    }
    return result.toString();
}

Просто конвертируйте нано-секунды в миллисекунды.

2 голосов
/ 29 ноября 2016

Java 8 теперь предоставляет самый лаконичный способ получения текущей метки времени Unix:

Instant.now().getEpochSecond();
2 голосов
/ 18 июля 2013
TimeUnit.SECONDS.convert(start6, TimeUnit.MILLISECONDS);
1 голос
/ 16 октября 2015

Для преобразования миллисекунд в секунды, начиная с 1 секунды = 10³ миллисекунд:

//here m will be in seconds
long m = System.currentTimeMillis()/1000;

//here m will be in minutes
long m = System.currentTimeMillis()/1000/60; //this will give in mins
1 голос
/ 03 октября 2012
// Convert millis to seconds. This can be simplified a bit,
// but I left it in this form for clarity.
long m = System.currentTimeMillis(); // that's our input
int s = Math.max(.18*(Math.toRadians(m)/Math.PI),Math.pow(Math.E, Math.log(m)-Math.log(1000)));
System.out.println( "seconds: "+s );
...