⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 cancelabletimerqueue.hxx

📁 这是国外的resip协议栈
💻 HXX
字号:
#ifndef resip_CancelableTimerQueue_hxx#define resip_CancelableTimerQueue_hxx#include <map>#include <limits.h>#include <iosfwd>#include "rutil/Timer.hxx"#include "rutil/HashMap.hxx"#include "rutil/Inserter.hxx"using namespace std;namespace resip{template<class T>class CancelableTimerQueue{    public:      CancelableTimerQueue() : mNextId(0) {};      ~CancelableTimerQueue() {};      typedef long Id;   private:      typedef std::multimap< UInt64, std::pair<T, Id> > TimerMap;      typedef HashMap<Id, UInt64> IdToTimer;   public:      Id addRelative(T msg,                     unsigned int offset)      {         return addTimer(msg, resip::Timer::getTimeMs() + offset);      }      //returns true if the id existed      bool cancel(Id id)      {         typename IdToTimer::iterator j = mIdToTimer.find(id);         if (j == mIdToTimer.end())         {            return false;         }                  for (typename TimerMap::iterator i = mTimerMap.lower_bound(j->second); i != mTimerMap.upper_bound(j->second); i++)         {            if (i->second.second == id)            {               mTimerMap.erase(i);               mIdToTimer.erase(j);               return true;            }         }         //cerr << "mIdToTimer: " << Inserter(mIdToTimer) << endl;         //cerr << "Searching for ID: " << id << endl;         //cerr << "TimerMap state: " << Inserter(mTimerMap) << endl;         assert(mIdToTimer.size() == mTimerMap.size());         assert(0);      }      //get the number of milliseconds until the next event, returns -1 if no      //event is available      int getTimeout() const      {         if (mTimerMap.empty())         {            return -1;         }         else         {            if (mTimerMap.begin()->first - resip::Timer::getTimeMs() < 0)            {               return 0;            }            else            {               return mTimerMap.begin()->first - resip::Timer::getTimeMs();            }         }      }               bool available() const      {         return (!mTimerMap.empty() &&                  mTimerMap.begin()->first <= resip::Timer::getTimeMs());      }      T getNext()      {         assert(mIdToTimer.size() == mTimerMap.size());         assert(available());         typename TimerMap::iterator it = mTimerMap.begin();         mIdToTimer.erase(it->second.second);         T msg = it->second.first;         mTimerMap.erase(it);         assert(mIdToTimer.size() == mTimerMap.size());                  return msg;      }      void clear()      {         mTimerMap.clear();         mIdToTimer.clear();      }      bool empty() const      {         return mTimerMap.empty();      }      size_t size() const      {         return mTimerMap.size();      }   private:            Id addTimer(T msg, UInt64 expiry)      {         Id id = getNextId();         mTimerMap.insert(std::make_pair(expiry, std::make_pair(msg, id)));         mIdToTimer[id] = expiry;         assert(mIdToTimer.size() == mTimerMap.size());         return id;      }      Id getNextId()      {         mNextId++;         if (mNextId == INT_MAX)         {            mNextId = 1;         }         return mNextId;      }               Id mNextId;      IdToTimer mIdToTimer;      TimerMap mTimerMap;};}#endif/* ==================================================================== * The Vovida Software License, Version 1.0  *  * Copyright (c) 2004 PurpleComm, Inc.  All rights reserved. *  * Redistribution and use in source and binary forms, with or without * modification, are permitted provided that the following conditions * are met: *  * 1. Redistributions of source code must retain the above copyright *    notice, this list of conditions and the following disclaimer. *  * 2. Redistributions in binary form must reproduce the above copyright *    notice, this list of conditions and the following disclaimer in *    the documentation and/or other materials provided with the *    distribution. *  * 3. The names "VOCAL", "Vovida Open Communication Application Library", *    and "Vovida Open Communication Application Library (VOCAL)" must *    not be used to endorse or promote products derived from this *    software without prior written permission. For written *    permission, please contact vocal@vovida.org. * * 4. Products derived from this software may not be called "VOCAL", nor *    may "VOCAL" appear in their name, without prior written *    permission of Vovida Networks, Inc. *  * THIS SOFTWARE IS PROVIDED "AS IS" AND ANY EXPRESSED OR IMPLIED * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES * OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE, TITLE AND * NON-INFRINGEMENT ARE DISCLAIMED.  IN NO EVENT SHALL VOVIDA * NETWORKS, INC. OR ITS CONTRIBUTORS BE LIABLE FOR ANY DIRECT DAMAGES * IN EXCESS OF $1,000, NOR FOR ANY INDIRECT, INCIDENTAL, SPECIAL, * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY * OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE * USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH * DAMAGE. *  */

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -