我正在尝试使用TR1中的功能创建类似C#的多播委托和事件。或者Boost,因为boost :: function(大部分)与std :: tr1 :: function相同。作为概念证明,我尝试了这个:
template<typename T1>
class Event
{
private:
typedef std::tr1::function<void (T1)> action;
std::list<action> callbacks;
public:
inline void operator += (action func)
{
callbacks.push_back(func);
}
inline void operator -= (action func)
{
callbacks.remove(func);
}
void operator ()(T1 arg1)
{
for(std::list<action>::iterator iter = callbacks.begin();
iter != callbacks.end(); iter++)
{
(*iter)(arg1);
}
}
};
哪种有用,有点像。第callbacks.remove(func)
行没有。当我编译它时,我收到以下错误:
error C2451: conditional expression of type 'void' is illegal
这是由list
标题的第1194行引起的,该标题位于remove
函数中。造成这种情况的原因是什么?
答案 0 :(得分:5)
如果您正在寻找C ++中的多播代理,那么最好的选择是Boost.Signals2。您还可以使用Boost.Bind来使用成员函数进行回调。
您可以查看我的示例here,了解Boost.Signals和Boost.Bind的简单用法。
Boost.Signal提供终身管理功能,以确保不会向不再存在的订阅者发布事件。
答案 1 :(得分:4)
我认为这是完全相同的问题:comparing-stdtr1function-objects
(基本上你无法比较仿函数,这就是擦除或使用operator ==的任何东西都行不通的原因)
答案 2 :(得分:0)
您应该查看Sutter的Generalizing Observer