原理:
1、对于一个函数来说,他的函数名是函数的地址,一个指向函数代码的指针,是函数的入口地址,调用地址。
2、函数指针是一个指向函数的指针(获得函数名),函数指针指向函数名就可以替代该函数执行,去调用该函数
使用方法:
1,声明一个函数指针,统一接口(函数返回值类型和函数参数类型):返回值类型 (函数指针名)(参数列表)
函数指针名首先与结合表明是指针,之后与()结合表明是指向函数的指针
2,指针指向要执行的函数地址(函数名)
3,用函数指针替代函数名执行该函数
代码
#include<stdio.h>
#include<stdlib.h>
typedef int (*pfunc) (int,int); //该函数指针的别名为pfunc,统一接口
int getMax(int a,int b) {
return a > b ? a : b;
}
int getMin(int a,int b) {
return a < b ? a : b;
}
void test01(){
printf("getMax = %p, getMin = %p\n",getMax,getMin); //打印函数入口地址
}
void test02(){
int res = 0;
pfunc p = NULL; //定义函数指针变量p
p = getMax; //p得到getMax函数的入口地址
printf("p = %p\n",p); //测试验证
res = p(100,200); //使用p调用getMax
printf("res=%d\n", res);
p = getMin;
printf("p = %p\n",p);
res = p(100,200);
printf("res=%d\n", res);
}
int main(){
test01();
printf("----------------------\n");
test02();
return 0;
}