/**Copyright 2010 Research Studios Austria Forschungsgesellschaft mBH
*
* This file is part of easyrec.
*
* easyrec is free software: you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* easyrec is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with easyrec. If not, see <http://www.gnu.org/licenses/>.
*/
package org.easyrec.utils.spring.profile;
/**
* <p>
* Provides functionality for timing of java code.
* </p>
* Example of usage:
* <pre>
* Stopwatch stw = new Stopwatch();
* stw.start();
* //do some stuff
* long timePassed = stw.timePassed();
* stw.restart();
* //do some other stuff
* long timePassed2 = stw.stop();
* </pre>
* <p/>
* <p><b>Company: </b>
* SAT, Research Studios Austria</p>
* <p/>
* <p><b>Copyright: </b>
* (c) 2005</p>
* <p/>
* <p><b>last modified:</b><br/>
* $Author: pmarschik $<br/>
* $Date: 2011-02-11 11:04:49 +0100 (Fr, 11 Feb 2011) $<br/>
* $Revision: 17656 $</p>
*
* @author Florian Kleedorfer
*/
public class Stopwatch {
private long start = 0;
private boolean running = false;
public Stopwatch() {
}
public void start() {
if (running) {
throw new IllegalStateException("stopwatch is already running!");
}
running = true;
start = System.currentTimeMillis();
}
public void restart() {
if (!running) {
throw new IllegalStateException("stopwatch is not running!");
}
start = System.currentTimeMillis();
}
public long timePassed() {
if (!running) {
throw new IllegalStateException("stopwatch is not running!");
}
return System.currentTimeMillis() - start;
}
public long stop() {
if (!running) {
throw new IllegalStateException("stopwatch is not running!");
}
running = false;
return System.currentTimeMillis() - start;
}
}