【lesson13】进程控制初识

文章目录

进程创建

请你描述一下,fork创建子进程操作系统都做了什么?

fork创建子进程,系统里多了一个进程,进程 = 内核数据结构 + 进程代码数据,内核数据结构由OS维护,进程代码数据一般由磁盘维护。

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

1.分配新的内存块和内核数据结构给子进程

2.将父进程部分数据结构内容拷贝至子进程

3.添加子进程到系统进程列表当中

4.fork返回,开始调度器调度

创建子进程给子进程分配对应的内核结构,必须子进程自己独有,因为进程具有独立性!

理论上子进程也要有自己的代码和数据。

可是一般而言,子进程没有加载的过程,也就是子进程没有自己的代码和数据!!

所以子进程只能使用父进程的代码和数据。

代码都是不可读写只能读取,所以父子共享并没有问题。

数据可能被修改所以必须分离!

对于数据而言:

1.创建进程的时候就直接拷贝分离?并不是的,可能子进程根本不会用到该数据空间,即便用到,也有可能只是读取。

创建子进程不需要将不会被访问或者只会读取的数据拷贝一份。

但是什么样的数据值得拷贝呢?

将来会被父进程或者子进程写入的数据!!

一般而言即便是OS也无法提前知道哪些空间可能会被写入!

提前拷贝了,也不一定会立马使用。

所以OS选择了写实拷贝技术,对父子进程的数据进行分离!

OS为何要选择写实拷贝技术,对父子进程数据进行分离?

1.用的时候,在给你分配是高校使用内存的一种表现。

2.OS无法在代码执行前预知哪些空间会被访问。

fork之前进程代码是共享的fork之后还是共享的吗?是的。

相关推荐
采云 AI1 分钟前
小程序订单接单超时时间功能解释
服务器·小程序·apache
阿干tkl6 分钟前
误卸载 openssl-libs 的补救方法
linux·运维
PFinal社区_南丞7 分钟前
服务器进程日志分析:从头皮发麻到AI解救
运维·后端
G_H_S_3_8 分钟前
【网络运维】Docker网络:基础与实战
linux·运维·网络·docker
加藤不太惠11 分钟前
docker简单了解使用
运维·docker·容器
Lisonseekpan12 分钟前
RBAC 基于角色的访问控制模型详解与实践指南
java·服务器·网络·后端·spring·log4j
嵌入式学习和实践18 分钟前
Linux/Windows 系统架构查看、安装包选择指南(嵌入式开发场景适配)
linux·windows·系统架构
小安运维日记25 分钟前
RHCA - DO374 | Day09:自定义内容集和执行环境
linux·运维·服务器·系统架构·ansible·改行学it
2501_9388101134 分钟前
动态IP与短效IP的关系
服务器·网络协议·tcp/ip
TAEHENGV39 分钟前
提醒历史模块 Cordova 与 OpenHarmony 混合开发实战
运维·服务器