从boost deadline_timer的处理程序访问类数据

Access to class data from handler for boost deadline_timer

本文关键字:程序 访问 数据 处理 boost deadline timer      更新时间:2023-10-16

我能够为boost deadline_time(它是一个成员)创建一个处理程序通过将其声明为静态。不幸的是,这阻止了对非静态成员数据的访问。

我有一系列的暂停。所以我的想法是有一个单独的时间表同时维护超时事件的有序列表。每次发生下一个超时事件时,类将使用类中的下一个超时事件重新触发计时器计算此超时事件的剩余时间。

为了使这个概念发挥作用,处理程序需要操作非静态数据。但这是不可能的sence boost::asio需要一个静态处理程序。

有人知道怎么处理吗?

class TimerController {
public:
void setTimer(const eibaddr_t gad, const timesecs_t timedelay);  
void cancelTimer(const eibaddr_t gad);
bool isRunning(const eibaddr_t gad);
void setGad(const eibaddr_t gad);
static void timerHandler(const boost::system::error_code &ec); 
private:
boost::asio::deadline_timer* m_pTimer;
struct timerList_s
{
    eibaddr_t gad;
    boost::posix_time::ptime absTimeOut;
    timerList_s(const timerList_s& elem) : gad(elem.gad),
                                           absTimeOut(elem.absTimeOut)
    {
    };
    timerList_s(const eibaddr_t& pgad, const boost::posix_time::ptime pato) 
        : gad(pgad),
          absTimeOut(pato)
    {
    };
    timerList_s& operator= (const timerList_s& elem)
    {
        gad = elem.gad;
        absTimeOut = elem.absTimeOut;
        return *this;
    };
    bool operator< (const timerList_s& elem) const
    {
        return (absTimeOut < elem.absTimeOut);
    };
    bool operator== (const timerList_s& elem) const
    {
        return (gad == elem.gad);
    };
};
std::list<timerList_s> m_timers;

使用boost::bind可以按照以下方式deadline_.async_wait(bind(&client::check_deadline, this));deadline_timer类与非静态数据一起使用。例如,ASIO的示例中提供了详细信息,请点击此处。

我有一系列的暂停。所以我的想法是deadline_timer,同时维护超时事件的有序列表。每次发生下一个超时事件时,类都会使用类中的下一个超时事件重新触发计时器计算此超时事件的剩余时间。

这是一个非常奇怪的设计。

为了使这个概念发挥作用,处理程序需要操作非静态数据。但这是不可能的:asio需要静态处理程序。

boost::asio不需要静态处理程序,请参阅文档。它需要一个具有签名的处理程序

void handler(
  const boost::system::error_code& error // Result of operation.
);

这里的典型方法是使用boost::bind将成员函数绑定到处理程序。异步TCP客户端示例显示了一种方法。asio库的作者有一篇优秀的博客文章详细描述了这个概念,如果你理解它有困难的话。