2.2 为什么有进程的概念?

虚拟CPU

将应用程序构建成进程,可以独立于:

  • CPU的数量:物理CPU(physical CPU) 是CPU的真实硬件实例。多个进程可以用 分时系统 (time sharing) 的技术运行在同一个物理CPU上。每一个进程会有一个 虚拟CPU (virtual CPU/vCPU) :进程假定此CPU只对自己可用。
  • CPU的类型:虚拟CPU可以就被看作是物理CPU的抽象化,或者也可以是模拟不同CPU行为的软件。
  1. 每一个进程都可以分别有一个物理CPU。
  2. 所有的进程也可以“分时”同一个CPU,通过进程间的重复交替。
  3. 由于对于进程来说,CPU的分时是透明的,也就造成了每一个进程都有一个单独的CPU的假象:虚拟CPU。
  4. 拥有不同指令集的不同CPU可以被替换,而无需更改或者重新编译进程代码。
  5. 在不同物理CPU的情况下,虚拟CPU不仅仅是假象,更是在软件中实现并且模拟原始CPU的行为,流程保持不变。

虚拟CPU的好处

独立于CPU的个数和种类提供了几点重要的好处:

  • 多用户支持:多个用户,每个用户由一个或多个进程表示,可以在彼此不发觉的情况下共享同一个机器。
  • 多CPU透明化:为了使用多CPU而编写的程序可以准确运行。虽然在只有一个CPU可用时会略慢。
  • 可移植性:为一种类型的 CPU 编译的应用程序可以在不同的 CPU 上运行,而无需修改甚至无需重新编译。

例:

  1. 一个含有浮点运算指令(fpadd)的程序被执行。
  2. CPU获取并解码该指令。
  3. 若CPU支持浮点运算,则该指令直接被硬件执行。
  4. 相同的代码也可以由不支持浮点运算的CPU执行,而不需要做任何改动。浮点操作被虚拟CPU在软件中实现。
  5. 虚拟CPU获取指令,并对程序透明地使用相应的软件执行该指令。

模块化结构概念

一个应用程序可以被分为多个任务。每个任务可以被当成一个进程执行。通过多个合作的进程而不是单独一个进程有以下几点好处:

  1. 进程间的接口简单易懂。
  2. 每个进程可以独立被设计和研究。
  3. 通过重叠多个进程的执行来实现缩短空闲时间。
  4. 如果条件允许,不同的进程可以使用不同的CPU从而加快执行时间。

->2.3 进程控制模块

此博客仅用于自我学习的记录,如有不当请指正。08/09/2021

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值