如何多次发送SIGINT信号

时间:2015-07-15 17:50:36

标签: c++ c multithreading signals interrupt

我正在尝试从其他线程向主线程发送SIGINT信号。主线程已为信号分配了一个处理程序。当我发送第一个信号时,它被捕获在处理程序中。但我想连续发送信号。但在处理完第一个信号后,程序终止。我放了一个循环。所以我期望它应该继续发送这些信号。以下是我的代码

#include <signal.h>
#include <stdio.h>
#include <stdlib.h>
#include <windows.h>

static void catch_function(int signo) {
    puts("Interactive attention signal caught.");
}

DWORD WINAPI MyThreadFunction( LPVOID lpParam ) 
{
    while(1)
    {
        Sleep(50);
        puts("Raising the interactive attention signal.");
        if (raise(SIGINT) != 0) 
        {
            fputs("Error raising the signal.\n", stderr);
            return EXIT_FAILURE;
        }
    }
return 0;
}


int main(void) 
{
     if (signal(SIGINT, catch_function) == SIG_ERR) {
    fputs("An error occurred while setting a signal handler.\n", stderr);
    return EXIT_FAILURE;
    }

    HANDLE thread;
    DWORD  threadId;
    thread = CreateThread(NULL, 0, &MyThreadFunction, NULL, 0, &threadId);
    if(!thread)
    {
        printf("CreateThread() failed");
    }

    while(1)
    {
        Sleep(50);
    }
    puts("Exiting.");
    return 0;
}

以下代码的输出为

Raising the interactive attention signal.
Interactive attention signal caught.
Raising the interactive attention signal.

我也尝试过使用一个简单的例子。在这里,我发送信号3次,但只是第一次发现信号。之后程序终止了。以下是代码

#include <signal.h>
#include <stdio.h>

void signal_handler(int signal)
{
    printf("Received signal %d\n", signal);
}

int main(void)
{
    // Install a signal handler.
    signal(SIGINT, signal_handler);

    printf("Sending signal %d\n", SIGINT);
    raise(SIGINT);
    raise(SIGINT);
    raise(SIGINT);
    printf("Exit main()\n");
}

输出

sending signal 2
Received signal 2

所以我想知道如何继续从一个线程向其他线程发送一些信号?我希望我的一个线程将发送SIGINT信号,main将捕获它们并相应地执行一些操作。

1 个答案:

答案 0 :(得分:4)

通常在第一个信号之后,信号处理程序将重置为SIG_DFL(Unix V信号),并且SIG_INT的默认行为将退出程序。这就是你观察到的。因此需要重新安装处理程序。再次在处理程序中安装它:

void signal_handler(int signal)
{
    signal(SIGINT, signal_handler);
    printf("Received signal %d\n", signal);
}

更好的方法是使用sigaction,因为它没有这种行为。