SWITimeWatch.hpp
上传用户:xqtpzdz
上传日期:2022-05-21
资源大小:1764k
文件大小:2k
源码类别:

xml/soap/webservice

开发平台:

Visual C++

  1. #ifndef SWITIMEWATCH_HPP
  2. #define SWITIMEWATCH_HPP
  3. /****************License************************************************
  4.  * Vocalocity OpenVXI
  5.  * Copyright (C) 2004-2005 by Vocalocity, Inc. All Rights Reserved.
  6.  * This program is free software; you can redistribute it and/or
  7.  * modify it under the terms of the GNU General Public License
  8.  * as published by the Free Software Foundation; either version 2
  9.  * of the License, or (at your option) any later version.
  10.  *  
  11.  * This program is distributed in the hope that it will be useful,
  12.  * but WITHOUT ANY WARRANTY; without even the implied warranty of
  13.  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
  14.  * GNU General Public License for more details.
  15.  *
  16.  * You should have received a copy of the GNU General Public License
  17.  * along with this program; if not, write to the Free Software
  18.  * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA  02111-1307, USA.
  19.  * Vocalocity, the Vocalocity logo, and VocalOS are trademarks or 
  20.  * registered trademarks of Vocalocity, Inc. 
  21.  * OpenVXI is a trademark of Scansoft, Inc. and used under license 
  22.  * by Vocalocity.
  23.  ***********************************************************************/
  24. #include "SWIutilHeaderPrefix.h"
  25. #include "SWITimeStamp.hpp"
  26. /**
  27.  * class to facilitate computing elapsed time of operations.
  28.  * @doc <p>
  29.  **/
  30. class SWIUTIL_API_CLASS SWITimeWatch
  31. {
  32.   // ................. CONSTRUCTORS, DESTRUCTOR  ............
  33.   //
  34.   // ------------------------------------------------------------
  35.   /**
  36.    * Default constructor.
  37.    **/
  38.  public:
  39.   SWITimeWatch();
  40.   /**
  41.    * Destructor.
  42.    **/
  43.  public:
  44.   ~SWITimeWatch()
  45.   {}
  46.   // Starts the timer. This sets the reference time from which all new elapsed
  47.   // time are computed.  This does not reset the elapsed time to 0.  This is
  48.   // useful to pause the timer.
  49.  public:
  50.   void start();
  51.   // Stops the timer.
  52.  public:
  53.   void stop();
  54.   // Returns the elapsed time.  If the TimeWatch is in the stopped state,
  55.   // successive calls to getElapsed() will always return the same value.  If
  56.   // the TimeWatch is in the started state, successive calls will return the
  57.   // elapsed time since start() was called.
  58.  public:
  59.   unsigned long getElapsed();
  60.   // Sets the elapsed to 0 and resets the reference time to now.
  61.  public:
  62.   void reset();
  63.  private:
  64.   unsigned long _elapsed;
  65.  private:
  66.   SWITimeStamp _timestamp;
  67. };
  68. #endif