Linux下利用signal函数处置ctrl+c等信号

Linux下利用signal函数处理ctrl+c等信号

前言

    linux下可以通过信号机制来实现程序的软中断,是一个非常有用的编程方法。我们平时在程序运行的时候按下ctrl-c、ctrl-z或者kill一个进程的时候其实都等效于向这个进程发送了一个特定信号,当进程捕获到信号后,进程会被中断并立即跳转到信号处理函数。默认情况下一个程序对ctrl-c发出的信号(SIGINT)的处理方式是退出进程,所以当我们按下ctrl-c的时候就可以终止一个进程的运行。

signal函数

    但是有时候我们希望我们的程序在被信号终止之前执行一些特定的收尾流程,或者我们希望我们的程序在收到特定信号后能够执行我们自己定义的中断操作,在linux下我们可以通过signal函数实现上述的功能。

    例如:在Linux下面写一个程序,如果程序中出现死循环的话,我们就应该在键盘上按Ctrl+C来终止我们的程序,那么我们也可以捕获这个信号,然后执行我们自己的信号处理程序,输出一些有用的信息来帮助我们调试程序,这也算是一种技巧吧。如果我们不去捕获这个信号的话,那么信号产生后就去执行OS的信号处理程序。信号和中断很像,我们既可以使用OS的中断处理程序,也可以截获中断执行自己的中断处理程序。下面是一个多线程的例子:

#include <stdio.h>
#include <pthread.h>
#include <unistd.h>
#include <sys/wait.h>
#include <sys/types.h>

#define true 1

void * One(void * no) 
{
    while (true)
    {
    printf("NUAACS1\n");
    sleep(1);
    }
}

void * Two(void * no) 

{
    while (true)
    {
    printf("NUAACS2\n");
    sleep(1);
    }
}

void Stop(int signo) 
{
    printf("oops! stop!!!\n");
    _exit(0);
}

int main()
{
    int res;
    pthread_t A, B;

    signal(SIGINT, Stop); 
    res = pthread_create(&A, NULL, One, NULL);
    res = pthread_create(&B, NULL, Two, NULL);
    res = pthread_join(A, NULL);
    res = pthread_join(B, NULL);

    return 0;
}


    以上是网上的资料,但还有一点要注意的是,程序被中断并执行完中断函数后,也就是在中断函数中返回,那么程序会重新返回到中断前的位置继续执行之前的程序。信号处理函数只能返回void,不能返回指定的参数。

    另外,对于有些函数,程序的中断可能会打断这些函数的正常执行,比如说对于sleep函数,如果一个程序再sleep的途中被中断那么该程序会立刻结束sleep。