目录
2.void (*signal(int , void(*)(int)))(int);
一、函数指针
示例
首先请看下述代码
#include <stdio.h>
void test()
{
printf("hehe\n");
}
int main()
{
printf("%p\n", test);
printf("%p\n", &test);
return 0;
}
基本形式
其运行结果说明test和&test都是函数的地址,既然如此,那么可否用指针变量将函数的地址存放起来呢,答案是肯定的!那么以上述代码为例,如何用指针变量存放函数的地址呢?其形式如下:void (*pf)(); 其中void (*)()是函数指针类型,pf是变量名。注意这里的括号不能够省略,*和pf结合说明pf是一个指针,指向一个返回值为void 无参数的函数;如果不加(),那么void* pf()表示一个函数pf,其返回类型是void*。
两个令人头痛代码
1.(*(void (*)())0)();
这个代码的突破口是0,在0前面的 void (*)()是一个函数指针类型,将其放在0前面的作用是对0进行强制类型转化,将0处的地址转化为一个函数指针类型,然后解应用获得0地址处的函数,进行调用;
2.void (*signal(int , void(*)(int)))(int);
这串代码是一次函数声明,声明的函数名字为signal ,该函数有两个参数,第一个参数为int,第二个参数类型为函数指针,该函数指针指向的函数参数也是int,返回值是void, 整个signal函数的返回类型是一个函数指针,返回的函数指针指向的函数与signal函数的第二个参数相同。