1.理解函数声明
经典的《C缺陷与陷阱》中提到的模拟开机启动,调用位于地址0的子例程
(*(void (*)())0)() ;关于该调用语句的理解,首先从简单的函数声明开始
声明一个函数:
void func() ;
声明一个函数指针,指向这类函数的声明:
void (*p)() ;
而同样的强制转换适应于函数类型,如下所示:
(void (*p)()) value ;
现在value已经转换成一个指向函数的指针了,同样函数指针可以实现函数调用也可以作为返回值。?
(*(void)(*)() value)() ;
2.注意优先级的问题
什么时候是函数指针,什么时候是返回值为指针的函数?
int *pf() ; int (*pf)() ;
前者pf是函数,后者pf是指针,指向形参为空返回值为int型的函数。如何辨别?
首先()的优先级最高,所以第一个pf先与()结合时一个函数,而后者先与*结合是一个指针,是一个函数指针。
3.函数指针作为返回值
Linux内核信号函数signal的定义如下:
void (*signal(int, void (*)(int)))(int) ;
简化可以看做是void(*p)(int) ;而上面优先级()高于*,所以signal首先是一个函数,即p是一个函数,那么void(*)(int)是返回值,即signal函数的返回值是函数指针。