【lesson13】进程控制初识

文章目录

进程创建

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

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

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

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

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

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

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

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

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

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

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

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

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

对于数据而言:

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

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

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

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

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

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

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

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

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

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

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

相关推荐
loong_XL3 小时前
docker gpu容器镜像环境构建
运维·docker·容器
杨了个杨89824 小时前
nginx常见功能部署
运维·服务器·nginx
小天源6 小时前
linux漏洞一键扫描
linux·运维·服务器·漏洞扫描
eWidget6 小时前
InfluxDB迁移至金仓数据库的同城容灾实践:性能显著提升、运维效率优化,某能源企业实现RPO_5秒的高可靠时序数据管理
运维·数据库·能源·时序数据库·kingbase·kingbasees·金仓数据库
m0_696212686 小时前
个人微信api
运维·服务器
en-route7 小时前
SSH Key 与 GPG Key 区别详解:Git 使用中的身份与签名机制
运维·git·ssh
Web极客码7 小时前
区块链第 1 层与第 2 层有什么区别?
服务器·区块链
码农水水7 小时前
中国邮政Java面试被问:容器镜像的多阶段构建和优化
java·linux·开发语言·数据库·mysql·面试·php
wifi chicken8 小时前
Linux Wlan L3~L2封包逻辑详解
linux·网络·ping·封包
小白鸽i9 小时前
【LINUX】将源码驱动文件编译并生效
linux·运维·服务器