Есть ли секундомер в Java?
Есть ли секундомер в Java? В Google я нахожу только код секундомеров, которые не работают - они всегда возвращают 0 миллисекунд.
Этот код, который я нашел, не работает, но я не понимаю, почему.
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;
}
}
Ответы
Ответ 1
Вы найдете его в
http://commons.apache.org/lang/
Он называется
org.apache.commons.lang.time.StopWatch
Но он примерно делает то же самое, что и ваш. Если вам нужна более высокая точность, используйте
System.nanoTime()
Смотрите также этот вопрос:
Накладные расходы на измерение времени в Java
Ответ 2
Используйте класс Guava Stopwatch
.
Объект, который измеряет прошедшее время в наносекундах. Полезно измерять прошедшее время, используя этот класс вместо прямых вызовов System.nanoTime()
по нескольким причинам:
- Альтернативный источник времени может быть заменен для тестирования или для повышения производительности.
- Как задокументировано nanoTime, возвращаемое значение не имеет абсолютного значения и может интерпретироваться только как относительное значение другой метки времени, возвращенной nanoTime в другое время. Секундомер - более эффективная абстракция, потому что он показывает только эти относительные значения, а не абсолютные.
Stopwatch stopwatch = Stopwatch.createStarted();
doSomething();
stopwatch.stop(); // optional
long millis = stopWatch.elapsed(TimeUnit.MILLISECONDS);
log.info("that took: " + stopwatch); // formatted string like "12.3 ms"
Ответ 3
Теперь вы можете попробовать что-то вроде:
Instant starts = Instant.now();
Thread.sleep(10);
Instant ends = Instant.now();
System.out.println(Duration.between(starts, ends));
Выход находится в ISO 8601.
Ответ 4
Spring предоставляет элегантный класс org.springframework.util.StopWatch
(модуль с пружинным ядром).
StopWatch stopWatch = new StopWatch();
stopWatch.start();
// Do something
stopWatch.stop();
System.out.println(stopWatch.getTotalTimeMillis());
Ответ 5
Код не работает, потому что прошедшая переменная в getElapsedTimeSecs() не является float/double.
Ответ 6
Используйте System.currentTimeMillis()
чтобы получить время начала и время окончания и рассчитать разницу.
class TimeTest1 {
public static void main(String[] args) {
long startTime = System.currentTimeMillis();
long total = 0;
for (int i = 0; i < 10000000; i++) {
total += i;
}
long stopTime = System.currentTimeMillis();
long elapsedTime = stopTime - startTime;
System.out.println(elapsedTime);
}
}
Больше информации в этом уроке
Ответ 7
Нет встроенной утилиты секундомера, но с JSR-310 (Java 8 Time) вы можете сделать это просто.
ZonedDateTime now = ZonedDateTime.now();
// Do stuff
long seconds = now.until(ZonedDateTime.now(), ChronoUnit.SECONDS);
Я не оценил это правильно, но я бы предположил, что использование Guava Stopwatch более эффективно.
Ответ 8
попробуйте http://introcs.cs.princeton.edu/java/stdlib/Stopwatch.java.html
что очень легко
Stopwatch st = new Stopwatch();
// Do smth. here
double time = st.elapsedTime(); // the result in millis
Этот класс является частью stdlib.jar
Ответ 9
Простой из класса Секундомер:
import java.time.Duration;
import java.time.Instant;
public class StopWatch {
Instant startTime, endTime;
Duration duration;
boolean isRunning = false;
public void start() {
if (isRunning) {
throw new RuntimeException("Stopwatch is already running.");
}
this.isRunning = true;
startTime = Instant.now();
}
public Duration stop() {
this.endTime = Instant.now();
if (!isRunning) {
throw new RuntimeException("Stopwatch has not been started yet");
}
isRunning = false;
Duration result = Duration.between(startTime, endTime);
if (this.duration == null) {
this.duration = result;
} else {
this.duration = duration.plus(result);
}
return this.getElapsedTime();
}
public Duration getElapsedTime() {
return this.duration;
}
public void reset() {
if (this.isRunning) {
this.stop();
}
this.duration = null;
}
}
Использование:
StopWatch sw = new StopWatch();
sw.start();
// doWork()
sw.stop();
System.out.println( sw.getElapsedTime().toMillis() + "ms");
Ответ 10
use: com.google.common.base.Stopwatch, его просто и просто.
<dependency>
<groupId>com.google.guava</groupId>
<artifactId>guava</artifactId>
<version>23.0</version>
</dependency>
пример:
Stopwatch stopwatch = new Stopwatch();
stopwatch.start();
"Do something"
logger.debug("this task took " + stopwatch.stop().elapsedTime(TimeUnit.MILLISECONDS) + " mills");
эта задача заняла 112 мельниц
Ответ 11
попробуйте это
import java.awt.event.*;
import java.awt.*;
import javax.swing.*;
public class millis extends JFrame implements ActionListener, Runnable
{
private long startTime;
private final static java.text.SimpleDateFormat timerFormat = new java.text.SimpleDateFormat("mm : ss.SSS");
private final JButton startStopButton= new JButton("Start/stop");
private Thread updater;
private boolean isRunning= false;
private final Runnable displayUpdater= new Runnable()
{
public void run()
{
displayElapsedTime(System.currentTimeMillis() - millis.this.startTime);
}
};
public void actionPerformed(ActionEvent ae)
{
if(isRunning)
{
long elapsed= System.currentTimeMillis() - startTime;
isRunning= false;
try
{
updater.join();
// Wait for updater to finish
}
catch(InterruptedException ie) {}
displayElapsedTime(elapsed);
// Display the end-result
}
else
{
startTime= System.currentTimeMillis();
isRunning= true;
updater= new Thread(this);
updater.start();
}
}
private void displayElapsedTime(long elapsedTime)
{
startStopButton.setText(timerFormat.format(new java.util.Date(elapsedTime)));
}
public void run()
{
try
{
while(isRunning)
{
SwingUtilities.invokeAndWait(displayUpdater);
Thread.sleep(50);
}
}
catch(java.lang.reflect.InvocationTargetException ite)
{
ite.printStackTrace(System.err);
// Should never happen!
}
catch(InterruptedException ie) {}
// Ignore and return!
}
public millis()
{
startStopButton.addActionListener(this);
getContentPane().add(startStopButton);
setSize(100,50);
setVisible(true);
}
public static void main(String[] arg)
{
new Stopwatch().addWindowListener(new WindowAdapter()
{
public void windowClosing(WindowEvent e)
{
System.exit(0);
}
});
millis s=new millis();
s.run();
}
}
Ответ 12
Попробуйте следующее:
/*
* calculates elapsed time in the form hrs:mins:secs
*/
public class StopWatch
{
private Date startTime;
public void startTiming()
{
startTime = new Date();
}
public String stopTiming()
{
Date stopTime = new Date();
long timediff = (stopTime.getTime() - startTime.getTime())/1000L;
return(DateUtils.formatElapsedTime(timediff));
}
}
Использование:
StopWatch sw = new StopWatch();
...
sw.startTiming();
...
String interval = sw.stopTiming();
Ответ 13
Попробуйте это.
public class StopWatch {
private long startTime = 0;
private long stopTime = 0;
public StopWatch()
{
startTime = System.currentTimeMillis();
}
public void start() {
startTime = System.currentTimeMillis();
}
public void stop() {
stopTime = System.currentTimeMillis();
System.out.println("StopWatch: " + getElapsedTime() + " milliseconds.");
System.out.println("StopWatch: " + getElapsedTimeSecs() + " seconds.");
}
/**
* @param process_name
*/
public void stop(String process_name) {
stopTime = System.currentTimeMillis();
System.out.println(process_name + " StopWatch: " + getElapsedTime() + " milliseconds.");
System.out.println(process_name + " StopWatch: " + getElapsedTimeSecs() + " seconds.");
}
//elaspsed time in milliseconds
public long getElapsedTime() {
return stopTime - startTime;
}
//elaspsed time in seconds
public double getElapsedTimeSecs() {
double elapsed;
elapsed = ((double)(stopTime - startTime)) / 1000;
return elapsed;
}
}
Использование:
StopWatch watch = new StopWatch();
// do something
watch.stop();
Консоль:
StopWatch: 143 milliseconds.
StopWatch: 0.143 seconds.
Ответ 14
user1007522, я не знаю, почему ваш код не работает (похоже, asfer уже прокомментировал это), но у меня была такая же проблема с получением 0 miliseconds из com.google.common.base.Stopwatch.
Я делал
Stopwatch stopwatch = new Stopwatch();
doSomething();
logger.info("test took:" + stopwatch);
Теперь я делаю
Stopwatch stopwatch = new Stopwatch().start();
doSomething();
stopwatch.stop();
logger.info("test took:" + stopwatch);
и он работает, я получаю "тест взял: 26.81 с"
Ответ 15
Здесь вы можете найти удобный:
https://github.com/varra4u/utils4j/blob/master/src/main/java/com/varra/util/StopWatch.java
Использование:
final StopWatch timer = new StopWatch();
System.out.println("Timer: " + timer);
System.out.println("ElapsedTime: " + timer.getElapsedTime());
Ответ 16
Попробуй это.
Java Stopwatch Полностью рабочее решение
Здесь вы получите полностью рабочее решение.
Просто фрагмент из вышеупомянутого решения:
Вы можете создать класс, подобный приведенному ниже, и использовать метод start и stop этого класса до и после раздела кода, где вы хотите измерить время.
public class Stopwatch{
private long startTime;
private long stopTime;
/**
starting the stop watch.
*/
public void start(){
startTime = System.nanoTime();
}
/**
stopping the stop watch.
*/
public void stop()
{ stopTime = System.nanoTime(); }
/**
elapsed time in nanoseconds.
*/
public long time(){
return (stopTime - startTime);
}
public String toString(){
return "elapsed time: " + time() + " nanoseconds.";
}
}
Спасибо.