fork同一時候創建多個子進程的方法


Fork同一時候創建多個子進程方法

 

 

第一種方法:驗證通過 

特點:同一時候創建多個子進程。每一個子進程能夠運行不同的任務,程序 可讀性較好,便於分析,易擴展為多個子進程 

int main(void) 

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

pid_t p1 fork(); 

if( p1 == )

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

}

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM