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.

posted on 2019-03-08 10:44  梦*飞  阅读(225)  评论(0编辑  收藏  举报