乱数 n を生成し、n 回ループするプログラムがあります。
反復ごとに、 の値をランダム化し、sleeptime
fork を呼び出します。子プロセスは数秒間スリープしsleeptime
、インデックス変数の値で終了します。
その後、親は再びループし、各プロセスが終了するのを待ちます。各プロセスが終了するたびに、プロセスの pid と childid をログアウトしようとしていますが、ここで問題が発生しています。pid は順番に出力され、childid は 0 のままです。
私は何を間違っていますか?
int main(int argc, char* argv[])
{
// Wire up the timer
long time = elapsedTime(0);
/* Generate a random number between MINFORKS and MAXFORKS
*/
unsigned int seed = generateSeed(0);
int n = rand_r(&seed) % MAXFORKS + MINFORKS-1;
/* Log next step
*/
time = elapsedTime(1);
printf("%li: Number of forks = %i\n", time, n);
/* Hang on to the PIDs so we can wait for them after forking
*/
pid_t *PIDs = (pid_t *)(malloc(sizeof(*PIDs)*n));
/* Fork n times
*/
for (int i = 0; i < n ; i++)
{
/* Call fork() and retain the returned identifier
*/
pid_t processIdentifier = fork();
/* Randomize the child sleep time
*/
seed = generateSeed(0);
int sleeptime = rand_r(&seed) % MAXPAUSE + MINPAUSE;
/* Check for errors
*/
if (processIdentifier == -1) {
printf("Error: %i", errno);
}
if (!processIdentifier)
{
/* We're in the child process,
* sleep and then exit with
* i as the error code.
*/
usleep(sleeptime);
_exit(i);
}
else
{
/* We're in the parent:
* Store the PID and
* print out the results.
*/
PIDs[i] = processIdentifier;
time = elapsedTime(1);
printf("%li: Child %i, pid = %i, forked, waits %i usec\n", time, i, processIdentifier, sleeptime);
}
}
/* Log next step
*/
time = elapsedTime(1);
printf("%li: Finished forking, going to wait.\n", time);
/*
* Loop through the processes and wait for them
* to terminate. Then print the childid, and the
* the pid.
*/
for (int i = 0; i < n; i++)
{
/* Get the PID we want to track
*/
pid_t pid = PIDs[i];
/* Wait for the child process
* and grab it's status info
*/
int status = NULL;
waitpid(pid, &status, 0);
int childid = -1;
if(WIFEXITED(status))
{
childid = WTERMSIG(status);
}
/* Log the results
*/
time = elapsedTime(1);
printf("%li: Child %i, pid = %i, terminated\n", time, childid, pid);
}
/* All done!
*/
time = elapsedTime(1);
printf("All done. It only took %li milliseconds!", time);
}
免責事項、これは宿題です(リンクはこちら、いつでも消える可能性があります)が、私はすでにほとんどすべてを行っています。私はその一面を理解するのに苦労しています。