跟着这篇文章重新理解了一下:彻底攻克C语言指针

有一个例子感觉可以拿出来看看:
char *(*c[10])(int **p); *
这段声明定义了一个长度为10的数组c,数组中的每个元素都是指向函数的指针。每个函数接受一个类型为int **(指向指向整数的指针)的参数,并返回一个指向char的指针。
详细分解如下:
char *:函数返回类型是指向char的指针。(*c[10]):c是一个包含10个元素的指针数组,每个元素是指针。(*c[10])(int **p):数组中的每个元素都是指向一个函数的指针,该函数接受一个int **类型的参数并返回一个char *类型的指针。
所以,c是一个长度为10的函数指针数组,其中每个函数指针指向的函数接受一个int **类型的参数并返回一个char *类型的指针。
下面是一个定义和使用这种函数指针数组的示例:
函数定义
char *func1(int **p) {// 函数实现return "函数 1";
}char *func2(int **p) {// 函数实现return "函数 2";
}
主函数
#include <stdio.h>char *func1(int **p);
char *func2(int **p);int main() {char *(*c[10])(int **p); // 声明一个函数指针数组c[0] = func1; // 将函数指针赋值给数组的第一个元素c[1] = func2; // 将函数指针赋值给数组的第二个元素int *ptr;int **p = &ptr;printf("%s\n", c[0](p)); // 调用第一个函数printf("%s\n", c[1](p)); // 调用第二个函数return 0;
}
在示例中,c[0]被赋值为func1,c[1]被赋值为func2。当调用c[0](p)和c[1](p)时,它们分别调用func1和func2。