带有boost信号的C ++模板类2

时间:2014-08-14 15:02:11

标签: c++ templates boost-signals2

我正在尝试使用带有C ++模板的boost信号和插槽。以下是示例代码:

#include <iostream>
#include <sstream>
#include <string>

#include <boost/signals2/signal.hpp>

template<class T>
class JBase
{
public:
    JBase(T &d) : data(d)
    {}
    virtual ~JBase() {}
    virtual bool DoSomething(std::string &outStr) = 0;

protected:
T data;
};

class LToUse : public JBase<int>
{
public:
   LToUse(int d) : JBase<int>(d) {}
   virtual ~LToUse() {}
   bool DoSomething(std::string &outStr)
   {
      std::ostringstream s;
      s << data;
      outStr = s.str();
      return true;
   }
};

template<class T>
typedef boost::signals2::signal<void(const JBase<T> &jsonObj)>::slot_type Sig_t;

class CBHndlr
{
   CBHndlr()
   {
      // I get errors even on this line...??
      //Sig_t t = boost::bind(&CBHndlr::TestCb, this, _1);
      //m_Signal.connect(t)
   }

   template<class T>
   void TestCb(JBase<T> *obj)
   {

   }

private:
   template<class T>
   boost::signals2::signal<void(JBase<T>)> m_Signal;
};

template<class T>
void TestJL(JBase<T> *obj)
{
   std::string s;
   obj->DoSomething(s);
   std::cout << "Did Something: " << s;
}

当我编译时,我得到(编译)错误说:

  1. typedef模板是非法的
  2. 语法错误:缺少';'在标识符'Sig_t'之前
  3. 对模板使用增强信号有什么限制吗?仅供参考 - 我没有使用C ++ 11。

    非常感谢任何建议/帮助。

2 个答案:

答案 0 :(得分:2)

模板typedef 非法,但您可以在C ++ 11中使用using

template<class T>
using Sig_t = typename boost::signals2::signal<void(const JBase<T> &jsonObj)>::slot_type;

在C ++ 03中,

你可以封装在一个结构中:

template <typename T>
struct Sig
{
    typedef typename boost::signals2::signal<void(const JBase<T> &jsonObj)>::slot_type type;
};

然后使用Sig<T>::type

编辑:     以下内容可以为您提供帮助:

template <typename T>
class CBHndlr
{
   CBHndlr()
   {
      typename Sig<T>::type t = boost::bind(&CBHndlr::TestCb, this, _1);
      m_Signal.connect(t)
   }

   void TestCb(JBase<T> *obj) {}
private:
   boost::signals2::signal<void(JBase<T>)> m_Signal;
};

答案 1 :(得分:0)

您引发的问题是 typedef模板是非法的。它是,你不能有一个模板typedef,它与boost :: signals没什么关系。

在C ++ 11中,他们引入了您可以使用的类型别名

template<class T> using Sig_t = <your type>