Linux下的fork()函数

来源:互联网 发布:手机对讲机软件 编辑:程序博客网 时间:2024/04/28 15:36

fork(): 

fork的英文翻译是“分叉”,同样在Linux中我们也可以理解为如果使用了fork()函数,进程也会“分叉”。下面进行具体的说明fork()函数。

  1. 定义:通过系统调用创建一个与原进程几乎完全相同的进程,其中新产生的进程成为子进程。
  2. 原型:
    pid_t fork(void);//fid_t相当于int类型
  3. 特殊之处(“分叉”):函数只产生一个进程;调用一次,返回两次。
  4. 返回值:在新创建的进程(称为子进程)中返回0调用的fork原进程(称为父进程)中返回新进程的PID;出错返回负数。
  5. 运行先后:父进程在调用fork()函数之后,产生子进程,谁先运行与操作系统的系统调度算法和当前计算机环境相关。
  6. 孤儿进程:如果父进程结束,子进程未结束,则子进程就成为了孤儿进程,交由init处理,将其PPID设为1。
  7. 示例加深理解:
示例(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从缓冲区刷新到界面的条件分析问题。