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
}
更多詳情見請繼續閱讀下一頁的精彩內容: http://www.linuxidc.com/Linux/2016-11/137100p2.htm