C ++初始化静态函数指针数组

时间:2015-08-12 07:44:09

标签: c++ function-pointers static-members static-initialization

我想创建一个静态函数指针数组,所以我可以跳转到关于接收索引的某个函数。就像一个索引跳线。

想象一下这样的课:

Class A 
{ 
  private:
  static void 1stFunction();
  static void 2ndFunction();

  static void(*functionPointer[20])(void);

};

然后我希望functionPointer获取1stFunction和2ndFunction的值,甚至可能更多。 那么,我该如何初始化呢? 据我所知,当声明静态成员时,甚至可以在创建实例之前使用它。所以我虽然让我们初始化那个函数指针,所以稍后我可以像这样调用它

functionPointer[receivedIndex]();

所以我试着像这样在同一个.h文件中启动它

void (*A::functionPointer[])(void) =
{
    A::1stFunction,
    A::2ndFunction,
};

但是编译器给了我重新定义,它说它已经创建了。

所以,很确定我错过了什么。我不知道,如果它是语法或只是不可能这样做。 我知道类的成员函数的函数指针与普通函数指针不同......但这是一个静态函数,所以我认为它不属于一个实例,因此它应该与普通函数一起工作指针。

任何帮助将不胜感激。 感谢

2 个答案:

答案 0 :(得分:4)

以下是一个可能达到您需要的工作示例。

初始化列表需要C++11

最好在cpp文件中初始化静态成员,因为您不希望每次包含标头时都有静态成员的定义(这可能会导致链接问题)。

您可以使用所需的callf调用index,并根据函数指针数组的初始化调用相应的函数。

该计划的输出将是:

I am 2ndFunction

标头文件

class A
{
private:
  static void Function1();
  static void Function2();

  static void(*functionPointer[20])();

public:
  static void callf(int index);
};

<强>实施

#include <iostream>
#include "ex.h"

void(*A::functionPointer[20])() {
  A::Function1,
  A::Function2
};

void A::Function1() {
  std::cout << "I am 1stFunction" << std::endl;
}

void A::Function2() {
  std::cout << "I am 2ndFunction" << std::endl;
}

void A::callf(int index) {
  A::functionPointer[index]();
}

int main(int argc, char const *argv[]) {
  A::callf(1);
  return 0;
}

答案 1 :(得分:3)

这里有一个更现代的C ++方法(需要C ++ 14) 如果您不限于C ++ 03,我建议您探索lambda函数。

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

class A {
public:

  using f_type = std::function<void(void)>;
  f_type f1 = []() { std::cout << "f0" << std::endl;};
  f_type f2 = []() { std::cout << "f1" << std::endl;};
  static void f3() { std::cout << "f3" << std::endl; }

  std::vector<f_type> functions{f1, f2, f3};

};


int main() {

  A a;
  a.functions[0]();
  a.functions[1]();
  //adding custom lambda
  a.functions.emplace_back([](){ std::cout << "custom f" << std::endl;});
  a.functions[2]();

  return 0;
}

您可以将两个函数和lambda添加到容器中。