在Linux中,当程序调用fork()函数时,系统会创建新的进程,为其分配资源(存储数据和代码的空间),然后把原来进程的所有值都复制到新进程中,只有少量数值与原来的进程值不同,相当于复制了本身。
fork()系统调用,被调用一次,却能返回两次:父进程和子进程各自返回一次。可以通过fork()的返回值的不同来区分父进程和子进程。
fork()返回值:
a.如果fork()返回值为0,则当前进程为子进程(可以通过getpid()获取当前执行进程的PID);
b.如果fork()返回值大于0,则当前进程为父进程,返回值为创建的子进程的PID;
c.如果fokr()返回负值,表示fork出现错误。
下面是在Linux中测试的代码:
#include <unistd.h>
#include <stdio.h>
int main(){
pid_t fpid;
fpid = fork();
if (fpid < 0)
printf("Error in fork!");
else if (fpid == 0){// 子进程中
printf("I am child. Process id is %d\n",getpid());
}else{// 父进程中
printf("I am parent. Process id is %d and child pid is %d\n",getpid(),fpid);
}
return 0;
}
输出结果:
I am parent. Process id is 2643 and child pid is 2644
I am child. Process id is 2644
在执行语句 fpid = fork() 之前,只有一个进程在执行这段代码,执行之后,父进程和子进程同时执行。这两个进程差不多完全一样,都将执行 if(fpid<0)。fork()执行后,父进程有义务监控子进程的运行状态,并在子进程退出后,自己才能正常退出。