fork函数

fork函数

在操作系统中,fork() 是一个创建子进程的系统调用。它的作用是创建一个与当前进程几乎完全相同的新进程,这个新进程称为子进程,而调用 fork() 的原进程称为父进程。

fork() 的过程可以分为以下几个步骤:

  1. 复制地址空间: 在调用 fork() 时,操作系统会复制父进程的地址空间,包括代码段、数据段、堆和栈。这意味着子进程会得到父进程完全相同的内存映像。
  2. 复制文件描述符表: 父进程打开的文件描述符表也会被复制到子进程中。这样,子进程可以访问与父进程相同的文件、管道和套接字等资源。
  3. 修改返回值: 在子进程中,fork() 的返回值是 0,而在父进程中,返回的是子进程的进程 ID(PID)。这样父进程可以通过返回值区分自己和子进程。
  4. 调度子进程: 一旦子进程被创建,操作系统会将其放入就绪队列中,等待调度执行。
#include <unistd.h>
pid_t fork(void);
返回值:自进程中返回0,父进程返回子进程id,出错返回-1

进程调用fork,当控制转移到内核中的fork代码后,内核做:

  • 分配新的内存块和内核数据结构给子进程
  • 将父进程部分数据结构内容拷贝至子进程
  • 添加子进程到系统进程列表当中
  • fork返回,开始调度器调度

在这里插入图片描述

当一个进程调用fork之后,就有两个二进制代码相同的进程。而且它们都运行到相同的地方。但每个进程都将可以开始它们自己的旅程,看如下程序。

#include<stdio.h>
#include<unistd.h>
#include<sys/types.h>

int main()
{
  int ret = fork();
  if(ret < 0)
 {
  perror("fork");
  return 1;
 }
  else if(ret== 0)
 {
  printf("子进程: %d, ret = %d\n", getpid(),ret);
 }
  else
 {
  printf("父进程: %d, ret = %d\n", getpid(), ret);
 }
    sleep(3);
    return 0 ;
}

运行结果:

[root@hadoop100 yyz]# ./a.out
父进程: 4912, ret = 4913
子进程: 4913, ret = 0

fork之前父进程独立执行,fork之后,父子两个执行流分别执行。注意,fork之后,谁先执行完全由调度器决定。

fork函数返回值

  • 失败: <0
  • 成功:给父进程返回子进程的pid,给子进程返回0

fork常规用法

  • 一个父进程希望复制自己,使父子进程同时执行不同的代码段。例如,父进程等待客户端请求,生成子进程来处理请求。
  • 一个进程要执行一个不同的程序。例如子进程从fork返回后,调用exec函数。

fork调用失败的原因

  • 系统中有太多的进程
  • 实际用户的进程数超过了限制
  • 4
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值