1

我制作了一个包含多个进程的程序,每个进程都有多个线程。我想使用 ctrl-c 停止程序,并决定使用中断处理程序。为此,我使用 signal() 函数在按下 ctrl-c 时设置一个标志。大多数线程都包含其中没有阻塞语句的循环,并且只是在未设置标志时运行。设置标志后,循环结束并调用 pthread_exit()。一些线程包含一个阻塞语句,并且可能无法到达注意到标志更改并且循环可以结束的地步。

在下面的示例中,这将导致内存泄漏(没有 free() 的 malloc() )和未正确结束的进程。

我检查了许多问答,但找不到合适的解决方案。任何帮助将不胜感激!

我在下面添加了一个示例(伪代码):

int flag = 0;

int main(void)
{
    // when (CTRL-C) is pressed, execute the interrupt handler
    signal(SIGINT, interrupt_handler_STATSERVER);

    // -- THREAD1: continuously receive packets from the data server
    pthread_t receivePackets_thread;
    int rc = pthread_create(&receivePackets_thread, NULL,(void*) receiveFromDataServer, NULL);
    if (rc)
    {
        printf("ERROR; return code from pthread_create() is %d\n", rc);
        exit(-1);
    }
}


void* receiveFromDataServer(void)
{
    while(flag == 0)
    {
        //every loop, allocate memory for a packet
        packet = (ProcessedPacket*) malloc(sizeof(ProcessedPacket));
        if(packet == NULL)
        {
            // ERROR: mem allocation error
        }
        else
        {
            // wait for a connection
            //*** THE BLOCKING STATEMENT IS HERE ***
        }       
    }

    pthread_exit(NULL);
}

void interrupt_handler_STATSERVER(int signum)
{
    printf("STAT SERVER INTERRUPT!\n");
    flag = 1;   
}`
4

1 回答 1

1

确保在所有子线程上屏蔽 SIGINT,因为信号传递到单个任意线程而没有屏蔽信号。这保证了您的“管理线程”将获得 ctrl-c。然后,使用管理线程中的 pthread_kill 使用未屏蔽的信号向其他线程发送信号。这将中断您的阻塞调用并允许您测试标志等。

阅读: http: //man7.org/linux/man-pages/man7/signal.7.html

特别是标题为:信号掩码和未决信号的部分

使用pthread_sigmask检查和更改线程的信号掩码。

于 2013-08-24T23:21:47.063 回答