我不知道当前杀死子进程的方式是否正确。我希望当子进程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
或您可能想用于此目的的任何其他信号时存活。