PCB&&进程调度
一:PCB
PCB是用来描述进程的,里面包含了一些进程的核心信息.
1:pid
1:概念
pid是用来描述进程的id的,是进程的标识符
一台计算机,同一时刻,同一个应用程序,可能会产生多个进程,
而pid就是为了区别这些进程.
2:内存指针
1:概念
一个程序,在运行的时候,会把这个程序的指令和数据从硬盘上加载到内存,而这些指针,数据,在哪里就需要内存指针来进行描述.
这里的指针,不是一个,而是一组,这一组指针就告诉操作系统:该进程要运行的指令/数据都保存在内存的什么地方
3:文件描述符表
1:概念
一个进程运行的时候,会操作一些文件,就通过一个 "顺序表"这样的结构,记录下来当前这个进程,都打开哪些文件.
(要操作文件,需要首先打开文件)
二:进程调度
1:什么是进程调度
在任务管理器中,可以看到,系统中包含了很多的进程,而且每个进程都需要执行,执行就需要占用CPU资源,去CPU上执行.
但进程的数量,远远多于多核CPU的数量.
此时就需要进程调度来协调了.
2:并行执行
一个核心,同一时刻,只能运行一个进程,大多数电脑,都是16核心,而不能只让一个核心工作;
让这16个核心同时工作,就称为"并行执行"
3:并发执行
一个核心,不同时刻,可以执行不同的进程,这就称为"并发执行".
由于时间比较短,CPU切换进程的速度极快,人感知不到
并行执行:宏观,微观时间上都是同时执行
并发执行:宏观时间上:同时执行,微观时间上:是串行执行.
操作系统会按照并行+并发相互搭配,运行所有的进程
2:支持进程调度的PCB属性
2.1:状态
就绪状态:操作系统想让哪个进程执行,哪个进程就执行,
阻塞状态:该进程不能正常执行.
处于阻塞状态的进程,无法在CPU上执行,往往进程在等待IO的时候就会进入阻塞状态,
2.2:优先级
分配的内存资源存在倾斜,不同进程分配的资源不同
2.3.上下文
进程在CPU的执行过程中,会产生许多的"中间结果",在进程切换出CPU之前,就需要把这些中间结果(CPU的各种寄存器的值)保存到PCB的上下文中,下次这个进程回到CPU上执行的时候,就需要先把之前的存档恢复过来
2.4:记账信息
统计不同进程占用的CPU资源,如果某个(某些)进程占用的CPU资源太少,操作系统就会适当的多分配一些.