fork():
fork的英文翻译是“分叉”,同样在Linux中我们也可以理解为如果使用了fork()函数,进程也会“分叉”。下面进行具体的说明fork()函数。
- 定义:通过系统调用创建一个与原进程几乎完全相同的进程,其中新产生的进程成为子进程。
- 原型:
pid_t fork(void);//fid_t相当于int类型
- 特殊之处(“分叉”):函数只产生一个进程;调用一次,返回两次。
- 返回值:在新创建的进程(称为子进程)中返回0;调用的fork原进程(称为父进程)中返回新进程的PID;出错返回负数。
- 运行先后:父进程在调用fork()函数之后,产生子进程,谁先运行与操作系统的系统调度算法和当前计算机环境相关。
- 孤儿进程:如果父进程结束,子进程未结束,则子进程就成为了孤儿进程,交由init处理,将其PPID设为1。
- 示例加深理解:
示例(1):
#include<stdio.h>
#include<unistd.h>
int main()
{
int i=0;
for(;i<2;i++)
{
if(fork())
printf("A\n");
else
printf("B\n");
}
}
分析以上代码会输出什么?
综上分析,结果就很明了了,终端最终输出三个A,三个B。
示例(2):
#include<stdio.h>
#include<unistd.h>
int main()
{
int i=0;
for(;i<2;i++)
{
if(fork())
printf("A");
else
printf("B");
}
}
两个程序只是微妙的变化,这次会输出什么?分析完我们看结果:
虽然变化不大,可结果却大相径庭,这次终端会输出四个A,四个B。
通过两个代码及输出结果相对比,我们要明白fork()在创建子进程时,会把父进程的文本段,缓冲区都会复制;同时也要结合printf从缓冲区刷新到界面的条件分析问题。