system.currenttimemillis()を使用して数秒でタイムスパンを測定する方法は?
-
26-10-2019 - |
質問
変換する方法 System.currentTimeMillis();
秒まで?
long start6=System.currentTimeMillis();
System.out.println(counter.countPrimes(100000000)+" for "+start6);
コンソールに表示されます 5761455 for 1307816001290
。それが何秒なのか読めません。
何か助けがありますか?
解決
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");
他のヒント
そのようです:
(int)(milliseconds / 1000)
コードから、計算にかかった時間を測定しようとしているように見えます(現在の時間を把握しようとするのではなく)。
その場合、電話する必要があります currentTimeMillis
計算の前後に、差を取り、結果を1000で割ってミリ秒を秒に変換します。
Java 8は、現在のUNIXタイムスタンプを取得するための最も簡潔な方法を提供しています。
Instant.now().getEpochSecond();
私は最後の課題で次のコードを書きました、それはあなたを助けるかもしれません:
// 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();
}
ナノ秒をミリ秒に変換するだけです。
TimeUnit.SECONDS.convert(start6, TimeUnit.MILLISECONDS);
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
// 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 );
所属していません StackOverflow