我想创建一个静态函数指针数组,所以我可以跳转到关于接收索引的某个函数。就像一个索引跳线。
想象一下这样的课:
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,
};
但是编译器给了我重新定义,它说它已经创建了。
所以,很确定我错过了什么。我不知道,如果它是语法或只是不可能这样做。 我知道类的成员函数的函数指针与普通函数指针不同......但这是一个静态函数,所以我认为它不属于一个实例,因此它应该与普通函数一起工作指针。
任何帮助将不胜感激。 感谢
答案 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添加到容器中。