虚拟CPU
将应用程序构建成进程,可以独立于:
- CPU的数量:物理CPU(physical CPU) 是CPU的真实硬件实例。多个进程可以用 分时系统 (time sharing) 的技术运行在同一个物理CPU上。每一个进程会有一个 虚拟CPU (virtual CPU/vCPU) :进程假定此CPU只对自己可用。
- CPU的类型:虚拟CPU可以就被看作是物理CPU的抽象化,或者也可以是模拟不同CPU行为的软件。
- 每一个进程都可以分别有一个物理CPU。
- 所有的进程也可以“分时”同一个CPU,通过进程间的重复交替。
- 由于对于进程来说,CPU的分时是透明的,也就造成了每一个进程都有一个单独的CPU的假象:虚拟CPU。
- 拥有不同指令集的不同CPU可以被替换,而无需更改或者重新编译进程代码。
- 在不同物理CPU的情况下,虚拟CPU不仅仅是假象,更是在软件中实现并且模拟原始CPU的行为,流程保持不变。
虚拟CPU的好处
独立于CPU的个数和种类提供了几点重要的好处:
- 多用户支持:多个用户,每个用户由一个或多个进程表示,可以在彼此不发觉的情况下共享同一个机器。
- 多CPU透明化:为了使用多CPU而编写的程序可以准确运行。虽然在只有一个CPU可用时会略慢。
- 可移植性:为一种类型的 CPU 编译的应用程序可以在不同的 CPU 上运行,而无需修改甚至无需重新编译。
例:
- 一个含有浮点运算指令(fpadd)的程序被执行。
- CPU获取并解码该指令。
- 若CPU支持浮点运算,则该指令直接被硬件执行。
- 相同的代码也可以由不支持浮点运算的CPU执行,而不需要做任何改动。浮点操作被虚拟CPU在软件中实现。
- 虚拟CPU获取指令,并对程序透明地使用相应的软件执行该指令。
模块化结构概念
一个应用程序可以被分为多个任务。每个任务可以被当成一个进程执行。通过多个合作的进程而不是单独一个进程有以下几点好处:
- 进程间的接口简单易懂。
- 每个进程可以独立被设计和研究。
- 通过重叠多个进程的执行来实现缩短空闲时间。
- 如果条件允许,不同的进程可以使用不同的CPU从而加快执行时间。
->2.3 进程控制模块
此博客仅用于自我学习的记录,如有不当请指正。08/09/2021