1// excerpts from http://code.google.com/p/muduo/ 2// 3// Use of this source code is governed by a BSD-style license 4// that can be found in the License file. 5// 6// Author: Shuo Chen (chenshuo at chenshuo dot com) 7 8#ifndef MUDUO_NET_TIMERQUEUE_H 9#define MUDUO_NET_TIMERQUEUE_H 10 11#include <set> 12#include <vector> 13 14#include <boost/noncopyable.hpp> 15 16#include "datetime/Timestamp.h" 17#include "thread/Mutex.h" 18#include "Callbacks.h" 19#include "Channel.h" 20 21namespace muduo 22{ 23 24class EventLoop; 25class Timer; 26class TimerId; 27 28/// 29/// A best efforts timer queue. 30/// No guarantee that the callback will be on time. 31/// 32class TimerQueue : boost::noncopyable 33{ 34 public: 35 TimerQueue(EventLoop* loop); 36 ~TimerQueue(); 37 38 /// 39 /// Schedules the callback to be run at given time, 40 /// repeats if @c interval > 0.0. 41 /// 42 /// Must be thread safe. Usually be called from other threads. 43 TimerId addTimer(const TimerCallback& cb, 44 Timestamp when, 45 double interval); 46 47 void cancel(TimerId timerId); 48 49 private: 50 51 // FIXME: use unique_ptr<Timer> instead of raw pointers. 52 typedef std::pair<Timestamp, Timer*> Entry; 53 typedef std::set<Entry> TimerList; 54 typedef std::pair<Timer*, int64_t> ActiveTimer; 55 typedef std::set<ActiveTimer> ActiveTimerSet; 56 57 void addTimerInLoop(Timer* timer); 58 void cancelInLoop(TimerId timerId); 59 // called when timerfd alarms 60 void handleRead(); 61 // move out all expired timers 62 std::vector<Entry> getExpired(Timestamp now); 63 void reset(const std::vector<Entry>& expired, Timestamp now); 64 65 bool insert(Timer* timer); 66 67 EventLoop* loop_; 68 const int timerfd_; 69 Channel timerfdChannel_; 70 // Timer list sorted by expiration 71 TimerList timers_; 72 73 // for cancel() 74 bool callingExpiredTimers_; /* atomic */ 75 ActiveTimerSet activeTimers_; 76 ActiveTimerSet cancelingTimers_; 77}; 78 79} 80#endif // MUDUO_NET_TIMERQUEUE_H 81