2

执行

我的代码

jmp_buf a;

void sig_handler(int signum) {
        if(signum == SIGINT) exit(0);

        printf("In the handler\n");
        sleep(2);
        alarm(3);
        longjmp(a,1);
}
int main(int argc, char *argv[]) {
    int j=0;
    struct sigaction sa;

    memset(&sa, 0, sizeof(struct sigaction));
    sa.sa_handler = sig_handler;
    sigfillset(&sa.sa_mask);
    sa.sa_flags = 0;
    sigaction(SIGALRM, &sa, NULL);

    alarm(2);
    j = setjmp(a);
    while(1){
       printf("In the main\n");
       pause();
        }
    return 0;
}

我认为这段代码的结果是

在主要。在处理程序中。在主要。在处理程序中。在主要。在处理程序中。在主要。在处理程序中。. . .

但它没有用。处理程序中未设置警报功能。当我删除 setjmp、longjmp 时,它运行良好。但我不想删除它们。setjmp 是否影响设置报警功能?如何解决这个问题。

4

1 回答 1

3

longjmp和信号的相互作用是未指定的。改为使用siglongjmp。此代码应该可以工作:

#include <stdio.h>
#include <string.h>
#include <signal.h>
#include <stdlib.h>
#include <unistd.h>
#include <setjmp.h>

sigjmp_buf a;

void sig_handler(int signum) {
        if(signum == SIGINT) exit(0);

        printf("In the handler\n");
        sleep(2);
        alarm(3);
        siglongjmp(a,1);
}

int main(int argc, char *argv[])
{
    int j=0;
    struct sigaction sa;

    memset(&sa, 0, sizeof(struct sigaction));
    sa.sa_handler = sig_handler;
    sigfillset(&sa.sa_mask);
    sa.sa_flags = SA_NODEFER;
    sigaction(SIGALRM, &sa, NULL);

    alarm(2);
    j = sigsetjmp(a, 1);
    while(1){
       printf("In the main\n");
       pause();
        }
    return 0;
}
于 2020-05-06T16:04:54.360 回答