LockStatistics.hh

00001 //********************************************************************
00002 //*** Thread/LockStatistics.hh
00003 //*** Copyright (c) 2003-2009 by Markus Winand <mws@fatalmind.com>
00004 //*** $Id: LockStatistics.hh,v 1.14 2009-03-02 14:16:46 mws Exp $
00005 //********************************************************************
00006 /*
00007 This file is part of ResourcePool.
00008 
00009 ResourcePool is free software; you can redistribute it
00010 and/or modify it under the terms of the GNU General Public License
00011 as published by the Free Software Foundation; either version 2 of 
00012 the License, or (at your option) any later version.
00013 
00014 ResourcePool is distributed in the hope that it will be
00015 useful, but WITHOUT ANY WARRANTY; without even the implied warranty
00016 of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
00017 GNU General Public License for more details.
00018 
00019 You should have received a copy of the GNU General Public License
00020 along with ResourcePool; if not, write to the Free Software
00021 Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA
00022 02111-1307  USA */
00023 
00024 #ifndef INCLUDED_THREAD_LOCKSTATISTICS_HH
00025 #define INCLUDED_THREAD_LOCKSTATISTICS_HH
00026 
00027 #ifndef INCLUDED_THREAD_LOCKSTATISTICSFWD_HH
00028 #include "LockStatisticsFwd.hh"
00029 #endif
00030 
00031 #ifndef POSIX_TIMERFWD_HH
00032 #include "POSIX/timerFwd.hh"
00033 #endif
00034 
00035 #ifndef INCLUDED_THREAD_LOCKFWD_HH
00036 #include "LockFwd.hh"
00037 #endif
00038 
00039 #include <iosfwd>
00040 
00041 namespace fatalmind {
00042 
00043 class LockUsageStatistics {
00044     public:
00045         inline LockUsageStatistics()
00046         : _lock(0)
00047         , _reclev(0)
00048         , _maxreclev(0)
00049         {
00050         }
00051         
00052         inline void stat_lock() {
00053             ++_lock;
00054             ++_reclev;
00055         }
00056 
00057         inline void stat_unlock() {
00058             if (_reclev > _maxreclev) {
00059                 _maxreclev = _reclev;
00060             }
00061             --_reclev;
00062         }
00063 
00064     friend std::ostream& operator<<(std::ostream& o, const LockUsageStatistics& s);
00065     private:
00066         int _lock;
00067         int _reclev;
00068         int _maxreclev;
00069 };
00070 
00071 } // namespace fatalmind
00072 
00073 #ifndef POSIX_TIME_HH
00074 #include "POSIX/time.hh"
00075 #endif
00076 
00077 namespace fatalmind {
00078 
00079 class LockTimingStatistics {
00080     public:
00081         inline LockTimingStatistics()
00082         : _waittime()
00083         {};
00084         typedef timer<MultiThreadedModel<LockStatistics<NopLockUsageStatistics,NopLockTimingStatistics> >, SingleThreadedModel<LockStatistics<NopLockUsageStatistics, NopLockTimingStatistics> > > _timer_t;
00085         POSIX::timespec<MultiThreadedModel<LockStatistics<NopLockUsageStatistics, NopLockTimingStatistics> > > _waittime;
00086     friend
00087         std::ostream& operator<<(std::ostream& o, const LockTimingStatistics& s);
00088 };
00089 
00090 } // namespace fatalmind
00091 
00092 #endif

Generated on Mon Nov 9 16:21:24 2009 for ResourcePool by  doxygen 1.5.3