fork同一时候建立多个子进程的方法

Fork同一时候建立多个子进程方法post

 

 

第一种方法:验证经过 spa

特色:同一时候建立多个子进程。每个子进程可以运行不一样的任务,程序 可读性较好,便于分析,易扩展为多个子进程 orm

int main(void) 进程

get

printf("before fork(), pid %d\n", getpid()); it

pid_t p1 fork(); io

if( p1 == )class

扩展

printf("in child 1, pid %d\n", getpid()); 循环

return 0; //若此处没有return p1 进程也会运行 pid_t p2=fork()语句

pid_t p2 fork(); 

if( p2 == 

printf("in child 2, pid %d\n", getpid()); 

return 0; //子进程结束。跳回父进程

Printf("hello world\");//没有打印

}

int st1, st2; 

waitpid( p1, &st1, 0); 

waitpid( p2, &st2, 0); 

printf("in parent, child pid %d\n", p1); 

printf("in parent, child pid %d\n", p2); 

printf("in parent, pid %d\n", getpid()); 

printf("in parent, child exited with %d\n", st1); 

printf("in parent, child exited with %d\n", st2); 

return 0; 

 

 

另一种方法: 验证经过 

特色:同一时候建立两个子进程。结构比較繁琐。程序可读性很差,不易扩展 

 

#include<stdio.h> 

#include<unistd.h> 

#include<sys/types.h> //这个头文件不能少,不然pid_t未定义 

main() 

printf("This is parent process%d\n",getpid()); 

pid_t p1,p2; 

if((p1=fork())==0)

printf("This is child_1 process%d\n",getpid()); 

}

Else

if((p2=fork())==0)

printf("This is child_2 process%d\n",getpid()); 

}

Else

wait(p1,NULL,0); 

wait(p2,NULL,0); 

printf("This is parent process%d\n",getpid()); 

 

 

第三种方法:for 循环方法 

特色:事实上每次循环仅仅是建立了单个进程。并无同一时候建立多个进程 

#include<stdio.h> 

#include<unistd.h> 

#include<sys/types.h> 

main() 

{

printf("This is parent process%d\n",getpid()); 

pid_t p1,p2; 

int i; 

for(i=0;i<=2;i++)

if((p1=fork())==0)

printf("This is child_1 process%d\n",getpid()); 

return 0;//这个地方很关键 

wait(p1,NULL,0); //父进程等待p1子进程运行后才干继续fork其它子进程

printf("This is parent process%d\n",getpid()); 

}

注意:标注的 return 对程序结果影响很是大 

 

无 return 状况 

 

#include<stdio.h> 

#include<unistd.h> 

#include<sys/types.h> 

main() 

printf("This is parent process%d\n",getpid()); 

pid_t p1,p2; 

int i; 

for(i=0;i<=2;i++)

if((p1=fork())==0)

printf("This is child_1 process%d\n",getpid()); 

//return 0;//这个地方很关键 

wait(p1,NULL,0); 

printf("This is parent process%d\n",getpid()); 

}

结论:父进程会生成 n(n+1)/2+1个子进程,为循环次数,本例中共同拥有 个子进程。 但实际上仅仅有 个是父进程产生的。其他都为子进程 fork()出来的。父进程fork3个进程,第一个子进程运行完以后又fork2个进程,第2个子进程fork1个进程。

 

 

 

正确的使用Linux中的用fork()由一个父进程建立同一时候多个子进程 的格式例如如下:

 

int status,i;

for (i 0; 10; i++)

{

  status fork();

  if (status == || status == -1) break;//每次循环时,假设发现是子进程就直接从建立子进程的循环中跳出来。不让你进入循环,这样就保证了每次仅仅有父进程来作循环建立子进程的工做

}

if (status == -1)

{

  //error

}

else if (status == 0) //每个子进程都会运行的代码

{

  //sub process

}

else

{

  //parent process

}

相关文章
相关标签/搜索