0

我正在为一个研究项目开发基于事件的架构。该系统目前使用 Qt 信号,但我们正试图远离 Qt,所以我需要一些几乎与 Qt 事件循环和跨线程信号一样工作的东西。

可能与我更好的判断相反,我选择使用可变参数模板来创建一个通用事件,该事件将用于在目标线程中执行回调。

template<typename dest, typename... args>
class Event {
  public:
    Event(dest* d, void(dest::*func)(args...), args... a)
      : d(d), func(func), pass(a...) { }

    virtual void perform() {
      (d->*func)(pass...);
    }

  protected:

    dest* d;
    void(dest::*func)(args...);
    args... pass;
};

我还没有找到任何表明这是否可能的东西。但是,我很难相信它不是。鉴于此,我想知道是否有办法做这样的事情,如果没有,为什么?另外,如果有人有更好的方法,我会欢迎这个建议。

4

2 回答 2

2

嗯。我想我得到了一些讨厌的东西。代码不是很漂亮或很好,但你可能明白了。您应该能够使用模板递归地存储任何类型的对象,并在调用函数时通过它们进行递归。

#include <iostream>

template<typename first_arg, typename... args>
class Event
{
   public:

      Event(void (*fn)(first_arg, args...), first_arg first, args... in) : m_func(fn), var(first, in...) {}

      void operator()()
      {
         var(m_func);
      }

   private:
      void (*m_func)(first_arg, args...);

      template <typename t_arg, typename... t_args>
      struct storage;

      template <typename t_arg>
      struct storage<t_arg>
      {
         storage(t_arg t) : m_var(t) {}

         template<typename t_func, typename... tt_args>
         void operator()(t_func fn, tt_args... p)
         {
            fn(p..., m_var);
         }

         t_arg m_var;
      };

      template <typename t_arg, typename t_arg2, typename... t_args>
      struct storage<t_arg, t_arg2, t_args...>
      {
         storage(t_arg t, t_arg2 t2, t_args... p) : m_var(t), m_storage(t2, p...) {}

         template<typename t_func, typename... tt_args>
         void operator()(t_func fn, tt_args... p)
         {
            m_storage(fn, p..., m_var);
         }

         t_arg m_var;
         storage<t_arg2, t_args...> m_storage;
      };

      storage<first_arg, args...> var;
};

void test(int a, float b)
{
   std::cout << a << std::endl << b << std::endl;
}

int main()
{
   Event<int, float> event(test, 10, 100.0);
   event();
}

另外,我认为 std::bind 做了类似的事情,但不确定:D

于 2010-09-30T21:12:05.377 回答
0

使用 boost::fusion::make_fused。见例子(对不起,日语......): http ://d.hatena.ne.jp/faith_and_brave/20100804/1280905506

于 2010-10-01T00:39:25.917 回答