#
include<unistd.h>
#
include<sys/types.h>
函数定义:
pid_t fork(
void);
(pid_t 是一个宏定义,其实质是int 被定义在#
include<
sys/types.h>中)
返回值: 若成功调用一次则返回两个值,子进程返回0,父进程返回子进程ID;否则,出错返回-1
函数说明:
一个现有进程可以调用fork函数创建一个新进程。由fork创建的新进程被称为子进程(child process)。fork函数被调用一次但返回两次。两次返回的唯一区别是子进程中返回0值而父进程中返回子进程ID。
子进程是父进程的副本,它将获得父进程数据空间、堆、栈等资源的副本。注意,子进程持有的是上述存储空间的“副本”,这意味着父子进程间不共享这些存储空间。
linux将复制父进程的地址空间内容给子进程,因此,子进程有了独立的地址空间。
为什么fork会返回两次?
由于在复制时复制了父进程的堆栈段,所以两个进程都停留在fork函数中,等待返回。因为fork函数会返回两次,一次是在父进程中返回,另一次是在子进程中返回,这两次的返回值是不一样的。过程如下图
调用fork之后,数据、堆栈有两份,代码仍然为一份但是这个代码段成为两个进程的共享代码段都从fork函数中返回,箭头表示各自的执行处
示例代码: # include< sys/types.h> //对于此程序而言此头文件用不到 # include< unistd.h> # include< stdio.h> int main( int argc, char ** argv ) { int pid = fork(); if (pid < 0) { // printf("error!"); } else if( pid == 0 ) { // printf("This is the child process!"); } else{ // printf("This is the parent process! child process id = %d", pid); } return 0; } fork()在Linux系统中的返回值是没有NULL的. Error Codes 出错返回错误信息如下: EAGAIN 达到进程数上限. ENOMEM 没有足够空间给一个新进程分配. fork函数的特点概括起来就是“调用一次,返回两次”,在父进程中调用一次,在父进程和子进程中各返回一次。 fork的另一个特性是所有由父进程打开的描述符都被复制到子进程中。父、子进程中相同编号的文件描述符在内核中指向同一个file结构体,也就是说,file结构体的引用计数要增加
本文详细介绍了Linux系统中fork函数的工作原理及其使用方法。通过fork函数,一个进程可以创建出一个几乎完全相同的副本(子进程),并且该函数会在父进程和子进程中分别返回不同的值。文章还解释了fork函数为何会在调用一次的情况下返回两次,并提供了示例代码。

1473

被折叠的 条评论
为什么被折叠?



