进程切换-

简介: 进程切换-

实验课之前有一些问题

中断机制

第一个问题:

interrupt的两个状态源头:

外中断多由随机中断(异步中断)造成,如鼠标点击,键盘输入;

内终端多由故障终端:程序运行异常,硬件异常,系统调用是更高一级的调用,需要进入内核模式,也算是一个异常中断。

第二个问题:

进程的上下文信息

进程切换需要保存上下文(context),保存操作系统运行该程序的一些基本信息,保护住此程序的内存区

从cpu的层面就是保存当前系统运行的寄存器内的内容(push入对应堆栈)

一般来说由硬件分辨双模式(dual mode),status=0为内核模式,status=1为用户模式。

一般发生中断时,cpu模式从user mode立刻切换到 kernel mode

对应这张图的判断状态码和处理中断程序阶段

进程切换

这里状态队列分为等待状态和就绪状态。

那么一个进程的状态究竟放在什么地方呢?

每个进程都有一个pcb相对应

所以一个进程完整的内存部分(context)包含什么呢?

但这些部分在内存中并非连续的而是离散的

猜测这里大概是虚内存,估计后面课程会有讲解,因为我们都知道硬件读取都是顺序的。

状态队列

不同的i/o设备由不同的等待队列,所以有多个等待队列

运行状态队列是没有的,理论上来说单核cpu只有一个进程处于运行状态

而且我们可以看到,他们查询进程实体时只需要查询链接的pcb即可

就绪队列出列

进程调度

其实就是调度器将存在的进程在各种状态之间切换

这里有一个问题下面有两个事件,一个事件是cpu执行分支子进程;一个事件是中断事件发生。这两个事件是主动还是被动?

我目前认为子进程分支执行是父进程调用,所以是主动;中断发生根据前面可以判断这里大概率不是调用i/o设备导致的中断,应该是父进程调用子进程产生的并发,如果是这样估计也是主动,但这里只是我的猜想。后面课程估计会有答案。

相关文章
|
5天前
|
Linux Shell 调度
【linux进程(五)】进程间切换以及环境变量问题
【linux进程(五)】进程间切换以及环境变量问题
|
5天前
|
存储 Linux C语言
【linux进程控制(一)】进程终止--如何干掉一个进程?
【linux进程控制(一)】进程终止--如何干掉一个进程?
|
5天前
|
存储 算法 Linux
Linux下进程的调度与切换
Linux下进程的调度与切换
|
5天前
|
监控
用c实现进程监控,如果某一进程退出则重启
用c实现进程监控,如果某一进程退出则重启
15 0
|
5天前
|
调度
进程有哪几种状态
进程有哪几种状态
|
6月前
|
调度
进程间同步
进程间同步
22 0
|
6月前
|
存储 算法 Java
深入理解操作系统中进程与线程的区别及切换机制(下)
本文首先介绍了进程的控制结构,即进程控制块(PCB),它是表示进程的数据结构,包含了进程的相关信息和资源。PCB之间通过链表连接,形成就绪队列和阻塞队列,用于进程调度和资源管理。接着,文章详细探讨了进程的切换过程。进程切换是为了保证公平分配CPU时间片,涉及保存和恢复进程的执行上下文、更新进程状态和调度算法选择等步骤。文中还提到了进程上下文切换的场景,如时间片用完、内存不足、高优先级进程需求等。最后,文章介绍了线程的概念和上下文切换过程。线程是进程中的独立执行流程,可以共享进程的资源。线程的上下文切换开销较小,只需要保存和恢复线程的寄存器和计数器等信息。
深入理解操作系统中进程与线程的区别及切换机制(下)
|
6月前
|
Java 调度
深入理解操作系统中进程与线程的区别及切换机制(上)
进程是正在运行的程序的实例,它可以包含一个或多个线程。我们了解了进程的执行方式,包括早期单核处理器上的顺序执行以及引入多任务概念实现的伪并行。我们还探讨了进程的状态模型。进程可以处于就绪、运行、阻塞和结束等不同的状态。就绪状态表示进程已经准备好运行,但还没有被调度执行。运行状态表示进程正在执行。阻塞状态表示进程被阻塞,需要等待某些事件的发生才能继续执行。结束状态表示进程已经完成执行。
深入理解操作系统中进程与线程的区别及切换机制(上)
|
11月前
|
NoSQL 算法 Linux
进程状态,优先级以及进程切换
进程状态,优先级以及进程切换
115 0
|
物联网 Linux 调度
进程的状态及切换|学习笔记
快速学习进程的状态及切换
143 0
进程的状态及切换|学习笔记