首先,引用一下函数指针的定义:
在C语言中,一个函数总是占用一段连续的内存区,而函数名就是该函数所占内存区的首地址。我们可以把函数的这个首地址(或称入口地址)赋予一个指针变量,使该指针变量指向该函数。然后通过指针变量就可以找到并调用这个函数。我们把这种指向函数的指针变量称为“函数指针变量”。
函数指针变量定义的一般形式为:
类型说明符 (*指针变量名)();
其中“类型说明符”表示被指函数的返回值的类型。“(* 指针变量名)”表示“*”后面的变量是定义的指针变量。最后的空括号表示指针变量所指的是一个函数。
其次,在函数指针的入参中,带有指针变量,目的是将变量的地址放到函数中,从而改变该变量的值。
下面给出一段演示的示例代码:
#include <stdio.h>
void add(int x, int y, int *result)
{
*result = x + y;
}
void sub(int x, int y, int *result)
{
*result = x - y;
}
int main()
{
int result;
void (*p)(int x, int y, int *result);
p = add;
(*p)(3, 4, &result);
printf("result = %d\n", result);
p = sub;
(*p)(10, 4, &result);
printf("result = %d\n", result);
}
演示的结果如下:
从上面的示例可以看出,函数指针的入参和出参类型是固定的,只不过是完成了不同运算方式;3个入参中可以有指针变量,该指针变量也可以是更复杂的结构体指针,以满足更加丰富的需求。