references:
[1] how to create two processes from a single Parent
[2] fork() in C
[3] linux中fork同時創建多個子進程的方法
fork的本質,就是復制,把當前進程復制一份,然后兩個進程并發地執行fork后面的語句,區別就是,子進程的fork返回值是0,父進程的fork返回值是子進程的pid,這也是區分父進程和子進程的方法,至于其他的內容,在fork之前的東西兩個進程的一樣的。
給出一個父進程和一個子進程的模板
int fd = fork();
if(fd < 0){exit(1);
} else if(fd == 0){// child code
} else {// father code
}
對于創建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}
}
先創建子進程1,然后父進程再繼續執行,創建子進程2,最后,3個進程能夠在框架內執行自己的代碼。
這是最好用的框架,能夠將3個進程都識別和區分開,不過如果創建n個子進程就會很麻煩。
因此,根據不同需求,也可以有別的寫法
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,保證子進程不會再進一步創建子進程。
然后其實子進程就可以干自己的事情了,比如執行個exec family
,執行其他進程什么的。
另外值得一說的是,如果父進程沒有等待子進程結束之后再結束的話,shell就會出現顯示錯亂。
就像下面這樣,但是僅僅是顯示錯亂而已,你可以直接正常輸入命令的。
reference
[1] Using fork() in simplest form need to hit enter to finish execution
[2] Why do shells call fork()?
至于為什么,那是因為,當shell執行命令的之后,也會先創建一個子shell,然后執行exec,再執行你想要執行的命令,執行結束后,再返回當前的shell。
我們用shell執行了父進程,結束后返回,就顯示ss@ss:$
了,而子進程仍然在執行,并且向shell輸出了child process
,所以就造成了上面的局面,但是僅僅是顯示問題而已,正常向shell輸入命令就好。