SIGINT半阻塞可能吗?

时间:2014-04-02 23:10:19

标签: c signals sigint

我试图处理SIGINT。我的程序中SIGINT的主要目的是取消当前搜索功能并打印当前可用的结果。但每当我尝试捕获SIGINT信号时,它就会关闭我的程序。 (我搜索过这么多,请不要说我没有搜索到足够的数据)

我试过了:

  1. 基本信号处理(如下所示)

  2. sigaction功能

  3. 非本地信号处理

  4. sigprocmask(每当我阻止信号时,procmask都会出现问题我无法抓住它,但我需要抓住并在屏幕上进行打印)

  5. 毕竟我已经用完搜索关键字来找到解决方案。任何的想法 ? (搜索关键字或代码的一部分或逻辑方式来做^^)

    注意:此文本可能有语法错误。对不起任何错误。

    #ifdef DEBUG
    #define DPRINT(file ,message ,arg)      fprintf(file ,message ,arg);
    #define NDPRINT(file ,message)          fprintf(file ,message);
    #endif
    
    static volatile sig_atomic_t isSignalCaught = 0;
    void SIGHandler(int signo);
    
    int main(int argc, char** argv)
    {
        file_t *files,*nextP;
    
        signal(SIGINT, SIGHandler);
    
        files = findFiles("/");
    
        while (files != NULL) {
            DPRINT(stderr, "%s\n", files->fileName.string);
            nextP = files->pNext;
            free(files->fileName.string);
            free(files);
            files = nextP;
        }
    
        return(0);
    }
    
    void SIGHandler(int signo)
    {
        file_t *nextP;
        if (signo == SIGINT) {
            isSignalCaught = 1;
        }
    }
    

1 个答案:

答案 0 :(得分:2)

这是一个如何做我认为你想做的事情的例子。

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

typedef void(*  sig_func_t  )(int);

volatile sig_atomic_t keep_looping = 1;

void sig_handler(int sig_number) {
    switch (sig_number) {
    case SIGINT:
        keep_looping = 0;
        break;
    }
}

int should_continue(void) {
    char line[256];
    while (1) {
        printf("Continue? (y/n) ");
        fgets(line, sizeof line, stdin);
        if (tolower(line[0]) == 'y') {
            keep_looping = 1;
            signal(SIGINT, sig_handler);
            return 1;
        }
        if (tolower(line[0]) == 'n')
            break;
    }
    return 0;
}

int main (void) {
    sig_func_t sig_func;

    sig_func = signal(SIGINT, sig_handler);
    if (sig_func == SIG_ERR) {
        perror("signal");
        exit(EXIT_FAILURE);
    }

    unsigned n = 0;
    printf("Starting...\n");

    while (1) {
        while (keep_looping)
            n++;

        printf("Current value: n=%u\n", n);

        if (!should_continue())
            break;
    }

    signal(SIGINT, sig_func);

    return EXIT_SUCCESS;
}