【lesson13】进程控制初识

文章目录

进程创建

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

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

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

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

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

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

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

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

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

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

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

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

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

对于数据而言:

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

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

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

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

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

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

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

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

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

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

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

相关推荐
茉莉玫瑰花茶3 小时前
工作流的常见模式 [ 1 ]
java·服务器·前端
米高梅狮子3 小时前
第2章 docker容器
运维·docker·云原生·容器·架构·kubernetes·自动化
kidwjb4 小时前
信号量在进程中的使用
linux·进程间通信
闵孚龙4 小时前
Claude Code Ultraplan 远程多代理规划全解析:AI Agent、CCR远程容器、异步规划、状态机、计划传送与企业级自动化治理
运维·人工智能·自动化
南京码讯光电技术有限公司5 小时前
工业无线AP选型指南:从WiFi 5到WiFi 6+5G CPE,如何构建全覆盖、零漫游、高可靠的智能工厂网络?
服务器·网络·5g
sulikey5 小时前
个人Linux操作系统学习笔记2 - gcc与库的理解
linux·笔记·学习·操作系统·gcc·
二宝哥6 小时前
Linux虚拟机网络配置
linux·运维·服务器
卧室小白6 小时前
docker网络与服务编排与集群
运维·docker·容器
陳10306 小时前
Linux:进程间通信 和 简单进程池
linux·运维·服务器
数字化顾问6 小时前
(122页PPT)数字化架构的演进和治理(附下载方式)
java·运维·架构