函数指针介绍:
函数指针:指针存的是函数的地址
Add或者&Add都是函数的地址,在调试中虽然两者的类型有差异,但是使用起来都一样
如何定义:
int (*pf)(int, int) = Add;
上面代码定义函数指针变量,int为Add的返回值,(int, int)为Add的参数类型
int Add(int i, int j)
{
return i + j;
}
int main()
{
int (*pf)(int, int) = Add;//函数名就是函数首地址,如果要加“&”,则需要解引用
int r = pf(3, 5);
printf("%p \n", pf);
printf("%p \n", Add);
//printf("%d ", Add);
printf("%d ", r);
return 0;
}
上述代码中 int r = pf(3, 5); 和 int r = Add(3, 5); 效果一样,可以直接通过传地址进行函数调用。
创建一个返回值为函数指针的函数
void ( * signal(int i, void(*p)(int)) )(int);
signal(int i, void(*p)(int))是一个 参数为int和函数指针的函数,代码表示的是声明singal函数,就是一个函数声明
singal函数的返回值是函数指针,指向的函数返回值为void类型,参数为int类型。
singal函数的返回类型是void ( * )(int);
起初认为代码声明的是函数返回值指向的函数
如果函数返回值指向arr函数
那么代码就等同于
void arr(int);
因为返回值就是arr的地址,就想当然地认为是singal的返回值直接取代arr,就是声明arr函数,但是这种想法是错误的
定义一个返回值为指针变量的函数的规范就是
void ( * signal(int i, void(*p)(int)) )(int);
类似于定义指针变量
int (*pf)(int, int) = Add;
要把指针放在 * 后面
同样的 typedef 也是
typedef void(*pf_t)(int);
代码的意思 pf_t 代替void(*)(int)执行
typedef void(*pf_t)(int);
void(*p1)(int);
pf_t p1;//两行代码效果一样
pf_t要放在 * 后面,而不是typedef void(*)(int) pf_t;//错误写法