2

首先我不得不说我必须知道从 std::bind 返回的数据类型。

我有一个定义为的结构

typedef struct
{
  UINT ID;
  CString NAME;
  boost::any Func;// 'auto' doesn't work here
} CALLBACK;
CALLBACK CallBackItems[];

Func 是一个函数持有者,我希望它持有不同类型的回调函数。

在某处我像这样初始化 CallBackItems:

CallBackItems[] =
{       
    { 1,    L"OnReady",       std::bind(&CPopunderDlg::OnReady, pDlg)           },
    { 2,    L"CustomFunction",std::bind(&CPopunderDlg::OnFSCommond, pDlg,_1,_2) }   
   //...................    more items here         
};

当我尝试在每个 CALLBACK 中使用“Func”时,我必须先转换它,然后像函数一样使用它。到目前为止,我尝试过:

 //CallBackItems[0].Func is binded from pDlg->OnReady(), pDlg->OnReady() works here,
   boost::any_cast<function<void()>>(CallBackItems[0].Func)();

   ((std::function<void()>)(CallBackItems[0].Func))();

它们都不起作用,有人知道如何从 std::bind 转换返回的变量吗?

4

1 回答 1

4

从返回的类型std::bind未指定:

20.8.9.1.3 函数模板绑定[func.bind.bind]

1 ...

template<class F, class... BoundArgs>
未指定 bind(F&& f, BoundArgs&&... bound_args);

您可以std::function用来存储它们,例如

void f( int ) {}
std::function< void(int) > f2 = std::bind(&f, _1);

在您的情况下,这意味着您在存储结果时可能需要转换类型std::bind

CallBackItems[] =
{     
    { 1, L"OnReady", std::function< void() >( std::bind(&CPopunderDlg::OnReady, pDlg) ) },
    { 2, L"CustomFunction", std::function< void(int,int) >( std::bind(&CPopunderDlg::OnFSCommond, pDlg,_1,_2) ) },                  
};

然后将其取回:

boost::any_cast<std::function<void()>>(CallBackItems[0].Func)();
于 2013-10-16T17:32:22.553 回答