考虑下面的C ++ 0x代码:
a_signal.connect([](int i) {
if(boost::any_cast<std::string>(_buffer[i]) == "foo")
{
base_class<>* an_object = new derived_class();
an_object->a_method(_buffer[i]);
}});
如何在Boost Lambda中正确查看(因为此C ++ 0x功能尚未在GCC 4.4中使用)?
答案 0 :(得分:11)
我认为这应该有效:
a_signal.connect(if_then(
bind((std::string(*)(any&))&any_cast, var(_buffer)[_1]) == "foo",
bind(&base_class<>::a_method,
ll_static_cast< base_class<>* >(
new_ptr<derived_class>()
),
var(_buffer)[_1]
)
)
);
bind
,if_then
,ll_static_cast
,new_ptr
,_1
,var
(我认为ref
也是如此)是boost::lambda
的成员。
但老实说,我个人拒绝使用这些代码:)