transcurrido tomar tiempos tiempo segundos nanosegundos medir imprimir ejecución ejecucion contador calcular algoritmo java milliseconds

tomar - tiempo en nanosegundos java



¿Cómo medir el intervalo de tiempo en segundos utilizando System.currentTimeMillis()? (9)

TimeUnit

Utilice la enum TimeUnit integrada en Java 5 y TimeUnit posteriores.

long timeMillis = System.currentTimeMillis(); long timeSeconds = TimeUnit.MILLISECONDS.toSeconds(timeMillis);

Cómo convertir System.currentTimeMillis(); a segundos?

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

La consola me muestra 5761455 for 1307816001290 . No puedo leer cuántos segundos son.

¿Alguna ayuda?


A partir de su código, parecería que está tratando de medir cuánto tiempo tomó un cálculo (en lugar de intentar averiguar cuál es la hora actual).

En ese caso, debe llamar a currentTimeMillis antes y después del cálculo, tomar la diferencia y dividir el resultado por 1000 para convertir milisegundos a segundos.


He escrito el siguiente código en mi última tarea, puede ayudarte:

// 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(); }

Solo convierte nano-segundos a milisegundos.


Java 8 ahora proporciona el método más conciso para obtener la marca de tiempo Unix actual:

Instant.now().getEpochSecond();


Para la conversión de milisegundos a segundos, desde 1 segundo = 10³ milisegundos:

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


al igual que:

(int)(milliseconds / 1000)


// 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 );


long start = System.currentTimeMillis(); counter.countPrimes(1000000); long end = System.currentTimeMillis(); System.out.println("Took : " + ((end - start) / 1000));

ACTUALIZAR

Una solución aún más precisa sería:

final long start = System.nanoTime(); counter.countPrimes(1000000); final long end = System.nanoTime(); System.out.println("Took: " + ((end - start) / 1000000) + "ms);


TimeUnit.SECONDS.convert(start6, TimeUnit.MILLISECONDS);