TimeTracker.hxx
上传用户:sy_wanhua
上传日期:2013-07-25
资源大小:3048k
文件大小:3k
源码类别:

流媒体/Mpeg4/MP4

开发平台:

C/C++

  1. #ifndef TimeTracker_HXX_
  2. #define TimeTracker_HXX_
  3. /* ====================================================================
  4.  * The Vovida Software License, Version 1.0 
  5.  * 
  6.  * Copyright (c) 2000 Vovida Networks, Inc.  All rights reserved.
  7.  * 
  8.  * Redistribution and use in source and binary forms, with or without
  9.  * modification, are permitted provided that the following conditions
  10.  * are met:
  11.  * 
  12.  * 1. Redistributions of source code must retain the above copyright
  13.  *    notice, this list of conditions and the following disclaimer.
  14.  * 
  15.  * 2. Redistributions in binary form must reproduce the above copyright
  16.  *    notice, this list of conditions and the following disclaimer in
  17.  *    the documentation and/or other materials provided with the
  18.  *    distribution.
  19.  * 
  20.  * 3. The names "VOCAL", "Vovida Open Communication Application Library",
  21.  *    and "Vovida Open Communication Application Library (VOCAL)" must
  22.  *    not be used to endorse or promote products derived from this
  23.  *    software without prior written permission. For written
  24.  *    permission, please contact vocal@vovida.org.
  25.  *
  26.  * 4. Products derived from this software may not be called "VOCAL", nor
  27.  *    may "VOCAL" appear in their name, without prior written
  28.  *    permission of Vovida Networks, Inc.
  29.  * 
  30.  * THIS SOFTWARE IS PROVIDED "AS IS" AND ANY EXPRESSED OR IMPLIED
  31.  * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
  32.  * OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE, TITLE AND
  33.  * NON-INFRINGEMENT ARE DISCLAIMED.  IN NO EVENT SHALL VOVIDA
  34.  * NETWORKS, INC. OR ITS CONTRIBUTORS BE LIABLE FOR ANY DIRECT DAMAGES
  35.  * IN EXCESS OF ,000, NOR FOR ANY INDIRECT, INCIDENTAL, SPECIAL,
  36.  * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
  37.  * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
  38.  * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY
  39.  * OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
  40.  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE
  41.  * USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH
  42.  * DAMAGE.
  43.  * 
  44.  * ====================================================================
  45.  * 
  46.  * This software consists of voluntary contributions made by Vovida
  47.  * Networks, Inc. and many individuals on behalf of Vovida Networks,
  48.  * Inc.  For more information on Vovida Networks, Inc., please see
  49.  * <http://www.vovida.org/>.
  50.  *
  51.  */
  52. static const char* const TimeTrackerVersion =
  53.     "$Id: TimeTracker.hxx,v 1.4 2001/06/27 01:43:45 bko Exp $";
  54. #include <stdlib.h>
  55. #ifndef WIN32
  56. #include <iostream.h>
  57. #else
  58. #include <iostream>
  59. #endif
  60. #include <time.h>
  61. class TimeTracker
  62. {
  63.     public:
  64.         TimeTracker(ostream& os): _os(os)
  65.         {
  66.            tv_sec = 0;
  67.            tv_usec = 0;
  68.         };
  69.         inline void endTime()
  70.         {
  71.            struct timeval tv = { 0, 0 };
  72.            struct timezone tz = { 0, 0 };
  73.            gettimeofday(&tv, &tz);
  74.            long long sec = tv.tv_sec - tv_sec;
  75.            long long usec = tv.tv_usec - tv_usec;
  76.            char msbuf[50];
  77.            sprintf(msbuf, "%3.3f msec", ((sec* 1000000) + usec)/1000.0);
  78.            _os << "Time spent:" << msbuf << endl;
  79.         }
  80.         inline void startTime()
  81.         {
  82.            struct timeval tv = { 0, 0 };
  83.            struct timezone tz = { 0, 0 };
  84.            gettimeofday(&tv, &tz);
  85.            tv_sec = tv.tv_sec;
  86.            tv_usec = tv.tv_usec;
  87.         }
  88.         ~TimeTracker() { }
  89.     private:
  90.         long tv_sec;
  91.         long tv_usec;
  92.         ostream& _os;
  93. };
  94. #endif