fork()函数 Linux

 # 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 == -1 ) {
  // 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
  没有足够空间给一个新进程分配.
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值