<signal.h>
中有一个复杂的函数声明。很叫人费解。
void (*signal(int sig, void (*handler)(int)))(int);
我们按照向右看向左看的黄金法则来分析这个函数声明。如果你不明白我在讲什么,请看 读懂C复杂声明的黄金法则 。
首先这个声明的主体是signal,这个应该没有争议。
向右看, (int sig, void (*handler)(int))
,括号和参数,说明signal是一个函数。
第一个整形参数 sig
不用多讲,第二个参数比较复杂 void (*handler)(int)
,这是一个函数指针,它指向的函数接收一个整形参数,没有返回值。
向左看,发现一个 *
,说明signal函数返回的是一个指针。
向右看,向左看,是一对(),这怎么理解。 (*)
表明是一个函数指针,就是说 signal
函数的返回值是一个函数指针。
再向右看, (int)
,说明signal返回的函数指针指向的函数接受一个整形参数。
向左看,是 void
,说明signal返回的函数指针指向的函数没有返回值。
综合来看,这个声明,是一个名叫signal的函数声明,其主体是 signal(int, void (*)(int))
,其返回值是 void (*)(int)
。
分成这样写就清楚多了。
typedef void (*callback)(int); callback signal(int sig, callback handler);
signal函数的作用是为某个信号设置新的处理函数(指针),如果成功,将返回之前的处理函数(指针)。
你可以将它返回的函数指针保存下来,方便以后重置该信号的处理函数。
感谢 SegmentFault 上朋友的答疑。