package com.vladium.utils.timing; // ---------------------------------------------------------------------------- /** * A simple interface for measuring time intervals. An instance of this goes * through the following lifecycle states: *
*
ready *
timer is ready to start a new measurement *
started *
timer has recorded the starting time interval point *
stopped *
timer has recorded the ending time interval point *
* See individual methods for details.

* * If this library has been compiled with {@link ITimerConstants#DO_STATE_CHECKS} * set to 'true' the implementation will enforce this lifecycle model and throw * IllegalStateException when it is violated. * * @author (C) Vlad Roubtsov, 2002 */ public interface ITimer { // public: ................................................................ /** * Starts a new time interval and advances this timer instance to 'started' * state. This method can be called from 'ready' state only. */ void start (); /** * Terminates the current time interval and advances this timer instance to * 'stopped' state. Interval duration will be available via * {@link #getDuration()} method. This method can be called from 'started' * state only. */ void stop (); /** * Returns the duration of the time interval that elapsed between the last * calls to {@link #start()} and {@link #stop()}. This method can be called * any number of times from 'stopped' state and will return the same value * each time.

* * @return interval duration in milliseconds */ double getDuration (); /** * This method can be called from any state and will reset this timer * instance back to 'ready' state. */ void reset (); } // end of interface // ----------------------------------------------------------------------------