fork创建多个子进程
references:
 [1] how to create two processes from a single Parent
 [2] fork() in C
 [3] linux中fork同時創(chuàng)建多個子進程的方法
fork的本質(zhì),就是復制,把當前進程復制一份,然后兩個進程并發(fā)地執(zhí)行fork后面的語句,區(qū)別就是,子進程的fork返回值是0,父進程的fork返回值是子進程的pid,這也是區(qū)分父進程和子進程的方法,至于其他的內(nèi)容,在fork之前的東西兩個進程的一樣的。
給出一個父進程和一個子進程的模板
int fd = fork(); if(fd < 0){exit(1); } else if(fd == 0){// child code } else {// father code }對于創(chuàng)建1個父進程和2個子進程,也是一樣的道理
int fd1,fd2;fd1 = fork(); if(fd < 0){exit(1); } else if(fd == 0){// child1 code } else {fd2 = fork();if(fd2 < 0){exit(1);} else if(fd2 == 0){// child2 code} else {// father code} }先創(chuàng)建子進程1,然后父進程再繼續(xù)執(zhí)行,創(chuàng)建子進程2,最后,3個進程能夠在框架內(nèi)執(zhí)行自己的代碼。
這是最好用的框架,能夠?qū)?個進程都識別和區(qū)分開,不過如果創(chuàng)建n個子進程就會很麻煩。
因此,根據(jù)不同需求,也可以有別的寫法
for(int i = 0; i < n; i++){int fd = fork();if(fd < 0){exit(1);} else if(fd == 0){// child i codebreak;} else {// father code} }最大作用的是break,保證子進程不會再進一步創(chuàng)建子進程。
然后其實子進程就可以干自己的事情了,比如執(zhí)行個exec family,執(zhí)行其他進程什么的。
另外值得一說的是,如果父進程沒有等待子進程結束之后再結束的話,shell就會出現(xiàn)顯示錯亂。
就像下面這樣,但是僅僅是顯示錯亂而已,你可以直接正常輸入命令的。
 
reference
 [1] Using fork() in simplest form need to hit enter to finish execution
 [2] Why do shells call fork()?
至于為什么,那是因為,當shell執(zhí)行命令的之后,也會先創(chuàng)建一個子shell,然后執(zhí)行exec,再執(zhí)行你想要執(zhí)行的命令,執(zhí)行結束后,再返回當前的shell。
我們用shell執(zhí)行了父進程,結束后返回,就顯示ss@ss:$了,而子進程仍然在執(zhí)行,并且向shell輸出了child process,所以就造成了上面的局面,但是僅僅是顯示問題而已,正常向shell輸入命令就好。
總結
以上是生活随笔為你收集整理的fork创建多个子进程的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
                            
                        - 上一篇: 成都欢乐谷让带吃的进去吗
 - 下一篇: wait系统调用