跟着这篇文章重新理解了一下:彻底攻克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
。