c 每n秒检查一次信号

标签 c signals sleep

我正在尝试编写一个程序,每 5 秒检查一次接收到的所有信号并根据这些信号改变输出。 我的主要问题是让代码实际上等待 5 秒,因为函数 sleep() 在处理信号后立即被中断。 我试图做的是将程序分成两个进程,只让 child 处理信号,并通过管道进行通信。 问题是,由于管道阻​​塞,在前 5 秒之后,父级将只是尝试在那里读取,基本上使 sleep 变得无用。

理论上,我应该能够只使用我包含的库(或者替代 pthread 库,这是一个任务)来解决这样的问题,否则我看到我可以使用其他库来使管道不阻塞,但在此刻我对如何解决这个问题缺乏想法(我也尝试过使用线程失败的尝试)。

我附上代码以供引用,在此先感谢。

#include <stdio.h>
#include <signal.h>
#include <stdlib.h>
#include <unistd.h>
#include <sys/wait.h>

int p[2];//pipe

void sigHandler (int sig) {
    char c;
    switch (sig) {
        case SIGUSR1:
            c = '1';
        break;
        case SIGUSR2:
            c = '2';
        break;
        case SIGALRM:
            c = '0';
        break;
        case SIGSTOP:
            exit (0);
        break;
    }
    write(p[1], &c, sizeof(char));
}


int main(int argc, char **argv) {
    int signals[3], sig, i;
    for (i=0; i< 3; i++) {
        signals[i] =0;
    }
    pid_t pid;
    char csig;
    pipe(p);

    /*fork code*/
    pid = fork();

    /*parent*/
    if (pid) { 
        close(p[1]);
        int proceed = 1;

        /*cycle keeps on indefinitely*/
        while (proceed) {
            sleep(15); //increased the time so I have time to send signals
            while (read(p[0], &csig, sizeof(char)) > 0) {
                sig=atoi(&csig);
                signals[sig]++;

                /*if alternating sigals, error*/
                if (signals[1] && signals[2]) {
                    printf("Error: alternating SIGUSR1 and SIGUSR2\n%d\t%d\n", signals[1], signals[2]);

                }
                /*if 2 consecutive signals, success*/
                if (signals[sig] == 2) {
                    printf("Success: two consecutive SIGUSR1 or SIGUSR2\n");
                }
                /*if three consecutive signals, exit*/
                if (signals[sig] == 3) {
                    kill(pid, SIGSTOP);
                    proceed = 0;
                    break;
                }
                /*make 0 any non repeating signal != sig*/
                for(i = 0; i< 3; i++) {
                    if (i != sig) {
                        signals[i] = 0;
                    }
                }
            }
        }
    /*child*/
    } else {
        close(p[0]);
        signal(SIGUSR1, sigHandler);
        signal(SIGUSR2, sigHandler);
        signal(SIGALRM, sigHandler);
        signal(SIGSTOP, sigHandler);
        while (1) {
            sleep(5); //no need to do anything else
        }
        exit(1);

    }
    return 0;
}

最佳答案

  1. 计算五秒后的时间。这次存储。
  2. 计算距离您在第 1 步中计算的时间还有多长时间。
  3. 睡那么久。
  4. 查看时间。
  5. 如果它等于或超过您在第 1 步中存储的时间,则您完成了。
  6. 转到第 2 步。

关于c 每n秒检查一次信号,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/53711535/

相关文章:

java - 电梯寻找楼层模拟中的逻辑存在缺陷

c - 使用 SIGKILL 进行不间断系统调用期间任务 "dying"状态

c++ - 在 2 个窗口之间传递数据。 Qt

c++ - 在循环C++中限制fps

linux - 空闲 bash 脚本,直到记录 CTRL+c 事件

algorithm - 可执行文件中包含的排序算法是否被信号 11 命令终止?

c - 当前 GCC(特别是在 Ubuntu 上)的默认 C -std 标准版本是什么?

C范围问题

c - 如何在 Window 7 后台运行 C 窗口程序

c - scanf 不放置终止空字节