All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.cedarsolutions.util.Timer Maven / Gradle / Ivy

There is a newer version: 5.8.4
Show newest version
/* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * *
 *
 *              C E D A R
 *          S O L U T I O N S       "Software done right."
 *           S O F T W A R E
 *
 * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * *
 *
 * Copyright (c) 2013 Kenneth J. Pronovici.
 * All rights reserved.
 *
 * This program is free software; you can redistribute it and/or
 * modify it under the terms of the Apache License, Version 2.0.
 * See LICENSE for more information about the licensing terms.
 *
 * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * *
 *
 * Author   : Kenneth J. Pronovici 
 * Language : Java 6
 * Project  : Common Java Functionality
 *
 * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
package com.cedarsolutions.util;

import java.io.Serializable;
import java.util.Date;

import com.cedarsolutions.exception.CedarRuntimeException;

/**
 * Measures elapsed time.
 *
 * 

* Basic usage is pretty simple: *

* *
 *    Timer timer = new Timer();
 *    timer.start();
 *    // do some stuff
 *    timer.stop();
 *    System.out.println("Elapsed time: " + timer.getElapsedTimeString());
 * 
* *

* Just keep in mind that the timer must be stopped before * you ask for its elapsed time. It's legal to stop the * timer more than once: just call stop() each time you need * to see how long the timer has been running. *

* * @author Kenneth J. Pronovici */ public class Timer implements Serializable { /** Serialization version number, which can be important to the GAE back-end. */ private static final long serialVersionUID = 1L; /** Start timestamp. */ private Date start = null; /** Stop timestamp. */ private Date stop = null; /** Create a timer. */ public Timer() { this(null, null); } /** Create a timer with a start timestamp, generally only useful for unit tests. */ public Timer(Date start) { this(start, null); } /** Create an timer with a start and stop timestamp, generally only useful for unit tests. */ public Timer(Date start, Date stop) { this.start = start; this.stop = stop; } /** Clear the timer, resetting the start and stop timestamp. */ public synchronized void clear() { this.start = null; this.stop = null; } /** Start the timer. */ public synchronized void start() { this.start = DateUtils.getCurrentDate(); } /** Stop the timer. */ public synchronized void stop() { this.stop = DateUtils.getCurrentDate(); } /** Whether the timer has been started. */ public synchronized boolean isStarted() { return this.getStart() != null; } /** Whether the timer has been stopped. */ public synchronized boolean isStopped() { return this.getStop() != null; } /** Get the start timestamp. */ public synchronized Date getStart() { return this.start; } /** Get the stop timestamp. */ public synchronized Date getStop() { return this.stop; } /** * Get the elapsed time as a timestamp. * @return Timestamp as from Date.getTime(). * @throws CedarRuntimeException If the timer has not been properly started and stopped. */ public synchronized long getElapsedTime() { try { long elapsedTime = this.stop.getTime() - this.start.getTime(); return elapsedTime < 0 ? 0 : elapsedTime; } catch (NullPointerException e) { throw new CedarRuntimeException("Timer has not been properly started and stopped."); } } /** * Get the elapsed time as a legible string. * @return String as from DateUtils.formatElapsedTime(). * @throws CedarRuntimeException If the timer has not been properly started and stopped. */ public String getElapsedTimeString() { long elapsedTime = this.getElapsedTime(); return DateUtils.formatElapsedTime(elapsedTime); } /** Set the start timestamp, overriding the start() method, intended for use with unit tests ONLY. */ public synchronized void setStartForUnitTest(Date start) { this.start = start; } /** Set the stop timestamp, overriding the stop() method, intended for use with for unit tests ONLY. */ public synchronized void setStopForUnitTest(Date stop) { this.stop = stop; } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy