首页 未命名正文

linux编程_Linux中fork同时建立多个子历程的方式

云返利网 未命名 2020-05-26 09:08:17 12 0

Fork同时建立多个子历程方式

第一种方式:验证通过

特点:同时建立多个子历程,每个子历程可以执行差别的义务,程序 可读性较好,便于剖析,易扩展为多个子历程

int main(void)

{

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

pid_t p1 = fork();

if( p1 == 0 )

{

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

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

}

pid_t p2 = fork();

if( p2 == 0 )

{

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 1 pid = %d\n", p1);

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

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

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

printf("in parent, child 2 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 0 对程序效果影响很大

无 return 0 情形

#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个子历程,N 为循环次数,本例中共有 7 个子历程, 但实际上只有 3 个是父历程发生的,其余都为子历程 fork()出来的。父历程fork了3个历程,第一个子历程执行完之后又fork了2个历程,第2个子历程fork了1个历程。

准确的使用Linux中的用fork()由一个父历程建立同时多个子历程 的花样如下:

int status,i;

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

{

  status = fork();

  if (status == 0 || status == -1) break;//每次循环时,若是发现是子历程就直接从建立子历程的循环中跳出来,不让你进入循环,这样就保证了每次只有父历程来做循环建立子历程的事情

}

if (status == -1)

{

  //error

}

else if (status == 0) //每个子历程都市执行的代码

{

  //sub process

}

else

{

  //parent process

【关于云返利网】

云返利网是阿里云、腾讯云、华为云产品推广返利平台,在各个品牌云产品官网优惠活动之外,云返利网还提供返利。您可以无门槛获得阿里云、华为云、腾讯云所有产品返利,在官网下单后就可以领取,无论是自己用、公司用还是帮客户采购,您个人都可以获得返利。云返利网的目标是让返利更多、更快、更简单!详情咨询13121395187(微信同号)