函数指针数组用于通过索引调用不同函数,适用于回调或状态机;首先定义函数指针类型,如typedef int (*BinaryOp)(int, int);,再声明数组BinaryOp func_array[3];,并用符合签名的函数初始化,如{add, sub, mul},最后通过func_array[0](5, 3)等形式调用。
在C++中,定义一个函数指针数组需要先理解函数指针对应的类型,然后声明一个该类型的数组。函数指针数组适用于需要通过索引调用不同函数的场景,比如回调机制或状态机处理。
函数指针的基本形式
假设有一个函数,返回值为 int,参数为两个 int,其函数指针类型为:
int (*func_ptr)(int, int);
这个变量 func_ptr 可以指向任何符合该签名的函数,例如:
int add(int a, int b) { return a + b; }
定义函数指针数组
要定义一个包含多个此类函数指针的数组,只需在声明时加上数组大小:
立即学习“C++免费学习笔记(深入)”;
int (*func_array[3])(int, int);
这表示 func_array 是一个大小为3的数组,每个元素都是指向“接受两个int参数并返回int”的函数的指针。
也可以使用 typedef 让定义更清晰:
typedef int (*BinaryOp)(int, int);
BinaryOp func_array[3];
这样更易读,且便于后续扩展。
初始化和使用示例
定义几个符合签名的函数:
int add(int a, int b) { return a + b; }
int sub(int a, int b) { return a – b; }
int mul(int a, int b) { return a * b; }
然后初始化数组:
BinaryOp func_array[3] = {add, sub, mul};
调用方式:
int result = func_array[0](5, 3); // 调用 add,结果为 8
result = func_array[1](5, 3); // 调用 sub,结果为 2
通过索引灵活选择函数,适合在循环或查表时使用。
基本上就这些。函数指针数组的关键是明确函数签名,再按数组方式组织指针。用 typedef 或 using 可提升代码可读性。不复杂但容易忽略细节。