将mem_fun存储在标准容器中

时间:2010-09-03 17:07:45

标签: c++ stl vector containers mem-fun

有没有办法创建vector< mem_fun_t< ReturnType, MyClass > >

我看到的错误是:

error C2512: 'std::mem_fun1_t<_Result,_Ty,_Arg>' : no appropriate default constructor available

3 个答案:

答案 0 :(得分:4)

我真的不明白为什么它不起作用,但它实际上是一个非常难看的解决方案。只需要vector<function<ReturnType(MyClass*)>>并且没有C ++ 03绑定中存在的那些问题。

答案 1 :(得分:3)

你当然可以创建这样一个载体。

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

struct MyClass
{
    int a()  { return 1; }
    int b()  { return 2; }
};

int main()
{
    std::vector<std::mem_fun_t<int, MyClass> > vec;
    vec.push_back(std::mem_fun(&MyClass::a));
    vec.push_back(std::mem_fun(&MyClass::b));
    MyClass x;
    for (size_t i = 0; i != vec.size(); ++i) {
        std::cout << vec[i](&x) << '\n';
    }
}

如果遇到问题,请仔细阅读错误消息。例如,std::mem_fun可以返回各种包装器,具体取决于您传递给它的内容。

或者实际上,切换到boost或C ++ 0x function


编辑:使用此特定错误消息,我假设您正在执行调用包含类型的默认构造函数(例如resize或使用向量的构造函数指定大小)。你不能使用这些功能。

答案 2 :(得分:2)

mem_fun_t符合要存储在容器中的要求(它是可复制构造和可分配的),所以答案是肯定的。

但是,它不是默认构造或可比较的,所以有些东西你不能用它们的容器做,包括:

  • 调整大小,除非您提供值以填充
  • 使用非零大小构造,除非您提供要填充的值
  • 比较容器

您看到的错误来自尝试调整大小或使用大小构建。