3

是否有可能创建一个std::vector可以持有std::function任何签名的?(函数参数都是预先绑定的。)

我试过std::vector<std::function<void()> >了,因为如果我只有一种std::function类型,我可以将任何函数绑定到它。

这似乎在向量中不起作用:如果我尝试将函数添加std::bind到具有除 之外的签名的向量中void(),我得到:

No matching member function for call to 'push_back'

有没有办法做到这一点?

编辑:

我只记得它std::function<void()>确实允许您绑定任何返回的函数,void只要参数预先绑定std::bind,它不允许您绑定任何签名,但出于我的目的,它足够通用,因此以下工作:

class A
{
public:
    void test(int _a){ return 0; };
};

A a;
std::vector<std::function<void()> > funcArray;
funcArray.push_back(std::bind(&A::test, std::ref(a), 0));
4

2 回答 2

12

这应该有效:

#include <iostream>
#include <functional>
#include <vector>

void hello() { std::cout << "Hello\n"; }
void hello2(const char * name) { std::cout << "Hello " << name << '\n'; }

int main()
{

    std::vector<std::function<void()>> v;
    v.push_back(hello);
    v.push_back(std::bind(hello2, "tim"));
    v[0]();
    v[1]();
}

你怎么样?

于 2012-05-12T15:41:15.433 回答
0

是否可以创建一个可以保存带有任何签名的 std::function 的 std::vector?(函数参数都是预先绑定的。)

因此,您想知道是否可以使用向量来保存不同类型的对象,除非您将它们全部包装在一个类型中?

是的,您可以将一堆具有相同类型的项目存储在一个向量中。


或者,也许您想问“我如何包装可调用对象以使它们具有我需要的类型?”

bind 可以处理特殊情况,您只需删除或重新排序参数即可获得可转换为通用类型的内容。为了处理可能需要选择返回类型、添加参数等的一般情况,您只需编写新函数。Lambda 可以很容易地做到这一点:

std::vector<std::function<common_signature> F;

double foo(std::string);
// for a common signature of void()
F.push_back([]{ foo("hello"); });

int bar(void);
// for a common signature of int (int)
F.push_back( [](int i) { return bar() + i; });

int baz(void);
// for a common signature of std::complex<double> (void)
F.push_back( []() -> std::complex<double> { return {0,baz()}; });
于 2012-05-12T17:16:45.857 回答