您的位置:首页 > 运维架构 > Linux

fork()函数 Linux

2012-03-03 21:09 183 查看


#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<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   没有足够空间给一个新进程分配.
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签:  linux 存储 null