标签:
#include <stdio.h>
#include <sys/types.h>
#include <unistd.h>
int main()
{
pid_t pid1;
pid_t pid2;
pid1 = fork();
pid2 = fork();
printf("pid1:%d, pid2:%d\n", pid1, pid2);
}
输出:
pid1:3411, pid2:3412 //父进程里返回两次
pid1:0, pid2:3413 //子进程1里返回两次
pid1:3411, pid2:0 //子进程2里返回一次
pid1:0, pid2:0 //孙进程3里返回一次
1)fork函数总是“调用一次,返回两次”,在父进程中调用一次,在父进程和子进程中各返回一次。fork在子进程中的返回值是0,而在父进程中的返回值则是子进程的id。
2)子进程在创建的时候会复制父进程的当前状态(PCB信息相同,用户态代码和数据也相同)。
3)程序运行的结果基本上是父子进程交替打印,但这也不是一定的,取决于系统中其它进程的运行情况和内核的调度算法。
Linux里面fork是用clone实现的。fork出来的进程跟父进程除了PID不一样,其他都一样(基本上),就是把父进程拷贝了一份。但是要注意在子进程实际执行前,拷贝的动作并不会发生,因为Linux认为clone以后是要exec的。exec会把子进程实际要执行的代码拷贝到地址空间。因为单纯的fork就是拷贝了个父进程,用处不大。
标签:
原文地址:http://www.cnblogs.com/CalvinWang/p/5457372.html