fork problem


 
Thread Tools Search this Thread
Top Forums Programming fork problem
# 1  
Old 01-24-2006
fork problem

Hi,

Consider the following piece of code:

int main(void) {

int i;
pid_t pidp;

for (i=0;i<4;i++) {
switch (pidp=fork()) {
case -1:
fprintf(stdout, "Error during fork.\n");
exit (1);
case 0:
fprintf(stdout, "From child: I am born.\n");
exit (0);
default:
fprintf(stdout, "From parent: Child %d has ID %d.\n", i+1, pidp);
}
}

exit(0);
}

I understand that this program is not protected while it is writing to stdout. Therefore, certain inconsistencies are bound to happen. But I am not able to comprehend the following observation.

When I run this program, the output is on the standard output and is the following (as expected):

From child: I am born.
From parent: Child 1 has ID 6412.
From parent: Child 2 has ID 6413.
From child: I am born.
From child: I am born.
From parent: Child 3 has ID 6414.
From child: I am born.
From parent: Child 4 has ID 6415.

However, when the output is redirected to a file (even if "tee" is used), the output has a lot of duplicated lines:

From child: I am born.
From parent: Child 1 has ID 6454.
From child: I am born.
From parent: Child 1 has ID 6454.
From parent: Child 2 has ID 6455.
From parent: Child 3 has ID 6456.
From child: I am born.
From parent: Child 1 has ID 6454.
From parent: Child 2 has ID 6455.
From child: I am born.
From parent: Child 1 has ID 6454.
From parent: Child 2 has ID 6455.
From parent: Child 3 has ID 6456.
From parent: Child 4 has ID 6457.

I figure that it is due to the stdout stream becuase using fflush before the print statements in the code fixes this inconsistency.

But could somebody explain what's exactly happening?

regards,
Quantum Teleporter!
# 2  
Old 01-24-2006
When you write to a file, it is buffered. Each time you fork, the child inherits that buffer with the parents output still in it. The child adds a line to the inherited buffer and exits, which flushes the buffer. Also the children are not guaranteed to exit in the order they were created.
# 3  
Old 01-24-2006
Thanks a lot for your reply! I appreciate it very much!

I understand that the order in which the children finish is uncertain in this program.

However, why doesn't the same thing (duplication of lines) happen when the output of the program is not redirected to a file?
# 4  
Old 01-24-2006
stdio looks at the output device (stdout). If it is a tty, output is line buffered.
# 5  
Old 01-25-2006
try this peice of code

The buffer from parent will be flushed all before the child will be called.

int main(void) {

int i;
pid_t pidp;

for (i=0;i<4;i++) {
switch (pidp=fork()) {
case -1:
fprintf(stdout, "Error during fork.\n");
fflush(NULL);
exit (1);
case 0:
fprintf(stdout, "From child: I am born.\n");
fflush(NULL);
exit (0);
default:
fprintf(stdout, "From parent: Child %d has ID %d.\n", i+1, pidp);
fflush(NULL);
}
}

exit(0);
}

rajesh
Login or Register to Ask a Question

Previous Thread | Next Thread

10 More Discussions You Might Find Interesting

1. UNIX for Dummies Questions & Answers

Very basic problem with fork() using c

Hi guys, I have the following code: int main(int argc, char *argv) { int pid1,pid2,i=0; pid1=fork(); i+=2; if(!pid1) i++; if(i%3) pid2=fork(); if (pid2==0) { printf("sea \n "); i-=1; } if(i>=2)... (4 Replies)
Discussion started by: pfpietro
4 Replies

2. UNIX for Dummies Questions & Answers

Problem with fork() while reading files

Good evening everyone. I have my finals and I'm facing a problem: I have a for cycle that is supposed to fork 2 children but somehow it forks only the first one. What am I doing wrong ? #include <fcntl.h> #include <stdio.h> #include <stdlib.h> #include <string.h> #include <time.h>... (1 Reply)
Discussion started by: pfpietro
1 Replies

3. Programming

Problem with fork() and execlp process

Hello everyone, this is my first post. I have a task to use a fork to create multiple processes and then use execlp to run another program to add 2 numbers. The problem I am having is we are supposed to use the exit() call in the execlp to return the small integer. This is a bad way to... (3 Replies)
Discussion started by: Johnathan_1017
3 Replies

4. Programming

problem with mutltiple fork()

Hi, can someone please help me with creating mutltiple fork.. I was expecting something like this: I am a child: 1 PID: 1215 I am a child: 2 PID: 1216 I am a child: 3 PID: 1217 I am a child: 4 PID: 1218 I am a child: 5 PID: 1219 I am a child: 6 PID: 1215 I am a child: 7 PID: 1216 I am a... (4 Replies)
Discussion started by: Placenzo
4 Replies

5. Programming

help in C of fork() problem

i am a beginner of C, and i tired to fork multiple child and all of them belongs to same parents and each of child responsible for printing individual data. but i don't have any idea how to do...... Can any body help? thanks a lot really. (7 Replies)
Discussion started by: wendy1089
7 Replies

6. Programming

Fork and then exec problem with signals

Hi All, In my program i am handling SIGHUP signal. In the handler i fork and then exec on child process same binary file which is running. Parent process will die after 10 mins. Now my child process which was exec with same binary file is not receiving SIGHUP signal. Below is the progran code:... (6 Replies)
Discussion started by: sushil_shalin
6 Replies

7. UNIX for Dummies Questions & Answers

simple fork() problem

I have this little program ... int main(void){ printf("Before"); fork(); printf("After"); } output is this..... BeforeAfterBeforeAfter Shouldnt it be.....BeforeAfterAfter After parent is forked child receives the copy of program and continues from next statement... (3 Replies)
Discussion started by: joker40
3 Replies

8. Programming

problem implementing fork

Hi, I was honing my linux programming skill when this nuisance started bugging me. I wanted to create an empty file creator program. While creating a large file it must print # for progress bar. But the output shows it happening reverse way. ie. first it copies file and shows the progress... (7 Replies)
Discussion started by: dheerajsuthar
7 Replies

9. UNIX for Advanced & Expert Users

Problem due to Fork Error

Hi, I have developed a datastage job...which has many process running in parallel..but because of Fork Error my job is not working:( Can any body help me out to solve this Fork error problem.:rolleyes: My Os is SUNOS. IS there any setting in Unix through admin where in if i set some paramter... (8 Replies)
Discussion started by: Amey Joshi
8 Replies

10. Programming

fork() problem

i'm just trying to make 2 process read from the same 1 line a time. For some reason only the child reads. #include<stdio.h> #include <sys/types.h> void getlinefromfilep(void); void getlinefromfilec(void); int see=0; FILE * fileptr1; //need globe variable to tell pro3 to stop main()... (3 Replies)
Discussion started by: ddx08
3 Replies
Login or Register to Ask a Question