您的位置:首页 > 其它

fork()函数解析

2016-06-27 21:16 211 查看
在了解fork()函数前,我们先来看个题

<span style="font-size:18px;">#include<stdio.h>
#include <unistd.h>
int main( ) {
fork( );
fork( );
fork( );
printf(“hello\n”);
return 0;
}</span>这个题目会输出几个hello呢?
接下来,我们去Linux中先去寻找这个答案;



不知道你是否知道是这个答案呢?如果不对,不要心急,我们来一步步的了解fork()这个函数

头文件

#include<unistd.h>/*#包含<unistd.h>*/

#include<sys/types.h>/*#包含<sys/types.h>*/

函数原型

pid_t fork( void);

(pid_t是一个宏定义,其实质是int 被定义在#include<sys/types.h>中)

返回值: 若成功调用一次则返回两个值,子进程返回0,父进程返回子进程ID;否则,出错返回-1

函数说明

一个现有进程可以调用fork函数创建一个新进程。由fork创建的新进程被称为子进程(child process)。fork函数被调用一次但返回两次。两次返回的唯一区别是子进程中返回0值而父进程中返回子进程ID。

子进程是父进程的副本,它将获得父进程数据空间、堆、栈等资源的副本。注意,子进程持有的是上述存储空间的“副本”,这意味着父子进程间不共享这些存储空间。

UNIX将复制父进程的地址空间内容给子进程,因此,子进程有了独立的地址空间。在不同的UNIX (Like)系统下,我们无法确定fork之后是子进程先运行还是父进程先运行,这依赖于系统的实现。所以在移植代码的时候我们不应该对此作出任何的假设。

接下来,我们用一个小程序再去看看他的特性





这就可以看出,子进程它返回的的确是0;

接下来,我们把程序稍稍修改一下,在看看他们的改变



结果为



从上图便可以推断出父子进程的相互关系,以及它是如何产生的。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签:  fork浅析