fork的作用是创建一个子进程。
摘自《Unix网络编程 卷一》:
fork有两个典型用法。
1)一个进程创建一个自身的副本,这样每个副本都可以在另一个副本执行其他任务的同时处理各自的某个操作。这是网络服务器的典型用法。
2)一个进程想要执行另一个程序。既然创建新进程的唯一办法就是调用fork,该进程于是首先调用fork创建一个自身的副本,然后其中一个副本(通常为子进程)调用exec把自身替换成新的程序。这是诸如shell之类程序的典型用法。
fork()函数会返回两次,分别返回为子进程和父进程,靠返回值来区分,如果返回值为0则当前在子进程里面,若返回值大于0则当前在父进程里面。
看下面例子:
#include <unistd.h>
#include <stdio.h>
int main() {
pid_t fpid; //fpid表示fork函数返回的值,实际是一个int类型
int count = 0;
//fork之前,只有一个进程在执行这段代码,但在执行这条语句后,就变成两个进程在执行了,这两个进程几乎完全相同
//,将要执行的下一条语句都是 if(pid==0)。这两个进程的执行没有先后顺序,靠系统的进程调度策略
fpid = fork();
if (fpid < 0)
printf("error in fork!");
else if (fpid == 0) {
printf("subprocess, myId: %d\n", getpid()); //getpid:获取进程id,getppid:获取父进程id
count++;
} else {
printf("parentprocess, subId:%d\n",fpid);
printf("parentprocess, myId: %d\n", getpid());
count++;
}
printf("统计结果是: %d\n", count);
return 0;
}
在下面的例子中,for循环的执行次数为N,那么printf执行的次数为2+4+...+2^N。
#include<stdio.h>
#include <unistd.h>
int main(){
int i=0;
int N = 2;
for(i=0;i<N;i++){
int pid = fork();
if(pid==0){
printf("sub %d\n",i);
}else{
printf("par %d\n",i);
}
}
return 1;
}
在下面的例子中,一共创建了20个进程,包括main。要首先明白fork()&&fork()||fork()跟( fork() && fork() )|| fork() 是一致的,要了解与或运算的短路原则。
另外,可以将每个fork()分为两个分支来计算。一个分支为>0,另一个分支为==0。画一个树状图,就一目了然了。
#include <stdio.h>
#include <unistd.h>
int main(int argc, char* argv[]){
fork();
fork() && fork() || fork();
fork();
return 0;
}
参考地址:http://blog.youkuaiyun.com/jason314/article/details/5640969