c++通过exec函数杀死子进程,但不杀死父进程和正常运行时间



我不知道当前杀死子进程的方式是否正确。我希望当子进程3的定时器(temp)达到0时,它杀死所有的子进程,然后父进程打印一条消息,然后退出。此外,我尝试使用sysinfo来获得子2中的正常运行时间,但是sysinfo结构体在我运行程序的环境中没有作为成员的正常运行时间。那么,如何使用exec函数从/usr/bin/uptime获取正常运行时间呢另外,不要告诉我把所有的东西都从主函数中分离出来,因为我要在弄清楚如何完成功能之后才这么做。

代码:

#include <string>
#include <ctime>
#include <iostream>
#include <sys/sysinfo.h>
#include <cstdlib>
#include <unistd.h>
#include <sched.h>
#include <assert.h>
#include <stdio.h>
#include <stdlib.h>
#include <signal.h>
#include <errno.h>
using namespace std;
pid_t parent_pid;
void sigquit_handler (int sig) {
assert(sig == SIGQUIT);
pid_t self = getpid();
if (parent_pid != self) _exit(0);
}
int main (string input) {
if (input.empty()) {
    input = "10";
}
signal(SIGQUIT, sigquit_handler);
parent_pid = getpid();
int number = atoi(input.c_str());
pid_t pid;
int i;
FILE* fp;
double uptime;
for(i = 0; i < 3; i++) {
    pid = fork();
    if(pid < 0) {
        printf("Error");
        exit(1);
    }
    else if (pid == 0) {
        if (i == 0) { //Child 1
            sleep(1);
            time_t t = time(0);   // get time now
            struct tm * now = localtime( & t );
            cout << (now->tm_year + 1900) << '-'
                    << (now->tm_mon + 1) << '-'
                    <<  now->tm_mday
                    << endl;
        }
        else if (i == 1) { //Child 2
            sleep(5);
            struct sysinfo info;
            cout << info.uptime << endl;
        }
        else { //Child 3
            int temp = number;
            int minute = temp / 60;
            int second = temp - (minute * 60);
            sleep(1);
            cout << minute << ":" << second << endl;
            temp--;
            if (temp == 0) {
                kill(-parent_pid, SIGQUIT);
            }
        }
    }
    else  {
            cout << "Program is Complete";
    }
}
}

另外,我尝试使用sysinfo来获得子2中的正常运行时间,但是sysinfo结构体在我运行程序的环境中没有作为成员的正常运行时间。那么,如何使用exec函数从/usr/bin/uptime

获取正常运行时间呢?

您可以在进程中设置alarm,并在时间耗尽时接收SIGALRM


我希望当子进程3的定时器(temp)达到0时,它杀死所有子进程,然后父进程打印一条消息,然后退出。

您可能希望通过调用setpgrp首先使父进程成为组领导,这样您就可以从组中的任何进程发送信号给具有kill(0, SIGHUP)的同一组中的所有进程(父进程及其子进程)。父进程必须为SIGHUP安装一个信号处理程序,以便能够在接收SIGHUP或您可能想用于此目的的任何其他信号时存活。

最新更新