signal函数解剖
解剖一下signal函数,理解函数指针和typedef
void (*signal(int signum,void(* handler)(int)))(int); 等价于下面两行
typedef void (*sighandler_t)(int);
sighandler_t signal(int signum,sighandler_t handler)
分析:先分析第一行,看到这一串的函数声明,不要慌,从内而外一点一点分析:
1. signal(int signum,void(* handler)(int))这是一个函数,函数名为signal
(1) 第一个形参:int signum,是一个整形变量;
(2) 第二个形参:void(*handler)(int),这是一个函数指针,指向:返回值为void型,且带一个int型的形参的函数。也就是说,这个
形参,是一个指针,或者说是一个地址,可以理解为这个形参是函数名,因为函数名是函数的入口地址。里面分析完了。
2. signal函数的外面是 void(*)(int),想一想,在定义或者声明函数的时候,都需要说明函数返回值的类型,这个signal函数的形参
已经明确了,但是返回值还不知道,这个void(*)(int)就是返回值类型,这个类型是一个函数指针,碰巧的是,这个函数指针指向
的函数类型和signal的第二个形参指向的类型相同,都是指向:返回值为空,且带一个int类型形参的函数。
3. 因此先用typedef定义一种数据类型,这个类型就是void(*)(int),将这种类型定义为,或者说是起一个名别,叫做sighandler_t
sighandler_t = void(*)(int),所以可以将void(*)(int)类型的函数,在声明或者定义的时候用sighandler_t。
4. signal函数返回值为void(*)(int)型,所以用sighandler_t代替,第二个形参是void(*)(int)型,所以用sighandler_t代替。
示例:
#include <stdio.h> #include <signal.h> void fun1(int num) { printf("111"); } int main() { signal(2,fun1); while(); }
运行结果,原先2号信号是ctrl+c会结束进程,但是现在,只要一按ctrl+c就会显示111.