我目前正在尝试实现一个类的成员函数,该函数允许设置回调,回调本身要么是一个成员函数(可能是一个不同的类),要么是一个非类的纯函数。
有了这样一个阶级,
#include <boost/signals2.hpp> // for callback
class CallbackSetter
{
template <typename T>
void setCallback(T &p_rCallback)
{
m_oCallback.connect(boost::bind(&p_rCallback, _1);
}
boost::signals2::signal<void(const std::string &p_rTLName)> m_oCallback;
}
CallbackSetter oSetter;
oSetter.setCallback(theFunction);适用于非会员方法。然而,我在某种程度上无法实现某种允许用户连接到not成员的东西。这就是我试过的:
class CallbackSetter
{
template <typename T, typename Cl,
typename std::enable_if_t<!std::is_class<Cl>::value>>
void setCallback(T &p_rCallback, Cl & p_rCallbackclass)
{
m_oCallback.connect(boost::bind(&p_rCallback, p_rCallbackclass, _1);
}
template <typename T, typename Cl,
typename std::enable_if_t<std::is_class<Cl>::value> >
void setSignalChangeCallback(T &p_rCallback, Cl & p_rCaller)
{
m_oObserverCallback.connect(boost::bind(&p_rCallback, p_rCaller, _1));
}
}由其他类的成员函数调用,如下所示:
#include <string>
class OtherClass
{
void caller()
{
m_oMyCS.setCallback(&OtherClass::executeMe, this);
}
void executeMe(std::string &p_rTag)
{
// do whatever with p_rTag
}
CallbackSetter m_oMyCS;
}最后
void noMemberExec(std::string &p_rTag)
{
// do whatever
}
int main()
{
OtherClass oOC;
oOC.caller();
CallbackSetter oCS;
oCS.setCallback(&noMemberExec, nullptr);
return 0;
}这里的任何帮助都欢迎!
P.S.:我使用的是VS 2015,这是一个错误。
C2783: error calling 'setCallback(T&, CL&)': could not deduce template argunemt for '__formal'发布于 2016-07-08 13:52:12
与其为setCallback()设置不同的重载,而且还要考虑不同的情况--只需提供一个:
template <class F>
void setCallback(F f)
{
m_oCallback.connect(f);
}用户只需提供一个可以用std::string const&调用的函数。如果我希望它调用一个接受单个参数的自由函数,我只需要这样做:
oCS.setCallback(noMemberExec);如果我希望它在类实例上调用一个成员函数,我会显式地这样做:
m_oMyCS.setCallback([this](std::string const& arg){ executeMe(arg); });无论哪种方式,我都要将一个可调用的单个参数传递到setCallback()中。
https://stackoverflow.com/questions/38267526
复制相似问题