我正在尝试使用带有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;
}
当我编译时,我得到(编译)错误说:
对模板使用增强信号有什么限制吗?仅供参考 - 我没有使用C ++ 11。
非常感谢任何建议/帮助。
答案 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>