一、操作系统的基本概念
1.操作系统的定义
操作系统:操作系统是指控制和管理整个计算机系统的硬件与软件资源,合理地组织调度计算机的工作和资源的分配,进而为用户和其他软件提供方便接口与环境的程序集合。操作系统是计算机系统中最重要的系统软件。
2.操作系统的四大特性
并发、共享、虚拟、异步
3.操作系统的身份
3.1 操作系统作为计算机系统资源管理者负责:
(1)处理机管理
(2)存储器管理
(3)文件管理
(4)设备管理在这里插入图片描述
3.2 操作系统作为用户与计算机硬件之间的接口负责提供:
(1)联机命令接口:适用于实时或分时系统,用户说一句系统做一句,可被用户直接使用。
(2)脱机命令接口:适用于批处理系统,用户说一堆,系统做一堆,可被用户直接使用。
(3)程序接口:由一组系统调用组成,用户在程序中使用这些系统调用来请求操作系统提供服务。
二、操作系统的发展与分类
1.手工操作系统
此时无操作系统,用户独占全机,CPU等待用户。
缺点:人机矛盾及CPU与IO设备之间速度不匹配。
2.批处理系统
为了解决人机矛盾及CPU与IO设备之间速度不匹配出现了批处理系统。
2.1 单道批处理系统
内存中始终保持一道作业,为了进一步提高资源利用率和系统的吞吐量引入了多道程序技术。
2.2多道批处理系统
允许的多个程序同时进入内存并在CPU中交替地进行,这些程序共享软硬件资源。
优点:各种资源得到充分利用,系统吞吐量大。
缺点:用户响应时间长,不能人机交互。
3.分时操作系统
把处理器分为很短的时间片,按时间片轮流把处理机分配给连记作业使用。
优点:解决了不能人机交互的问题。
缺点:不能优先处理紧急任务。
4.实时操作系统
能在某个时间限制内让某些紧急任务不需要等待时间片,直接上处理机。
优点:及时且可靠。
三、操作系统的运行环境和体系结构
1.特权指令
权限很高的指令,不允许用户使用,如:内存清零指令。
2.用户态与核心态
操作系统用一个寄存器中的一位判断系统处于用户态还是核心态。
用户态下只能执行非特权指令。
核心态下既可以执行非特权指令又可以执行特权指令。
3.内核程序与应用程序
内核程序是系统的管理者,运行在核心态。内核程序包括(时钟管理、中断处理、原语等)。
4.原语
原语属于操作系统最底层,最接近硬件的部分,其操作过程具有原子性,即操作过程中不能被打断。
5.内核
内核是计算机配置上的底层软件,是操作系统最基本的核心部分。
实现操作系统内核功能的程序就是内核程序。
根据对内核划分的不同还分为大内核和微内核。
大内核即将许多功能都作为内核运行在核心态,优点是性能高,缺点是代码庞大,结构混乱。
微内核即只将最基础的部分放到内核中,优点是内核功能少,结构清晰。
四、异常和中断
1.中断本质
发生中断或异常时,运行用户态的CPU会立即进入核心态,意味着需要操作系统介入,开展管理工作。中断是操作系统非常重要的概念。
2.中断的作用
(1)中断使COU从用户态切换到核心态,使操作系统获得计算机的控制权。
(2)中断发生后,当前运行的进程停止,并由操作系统内核对中断进行处理。
(3)对于不同的中断信号,有不同的处理方式。
(4)中断是用户态 -> 核心态的唯一途径! 有了中断才能实现多道程序并发。
3.中断的分类
内中断:中断信号来自于CPU内部,与当前执行的指令有关。(如系统调用)。
内中断还可分为:
(1)陷入(trap):有意而为之的异常,系统本身主动的,如系统调用。
(2)故障(dault):由错误条件引起,可能被故障处理程序修复,如缺页。
(3)中止(abort):由不可恢复的致命错误引起,系统无法自动修复,如整数除0。
外中断:中断信号来自于CPU外部,与当前执行的指令无关。(如IO操作完成了返回的信号)。
内外中断的主要区别是信号来自哪里。通过它来判断是内中断还是外中断。
4.外中断处理过程
(1)执行指令,检查是否有中断信号。
(2)关中断,保存程序的现场状态,此时CPU不会响应其他中断。
(3)保存CPU环境,为了中断服务之后能返回原来的程序,如(程序状态字PSW,程序计数器PC,以及各种寄存器)。
(4)根据中断信号类型,转入各种中断处理。
(5)恢复原进程CPU环境,程序继续执行。
PC的断点保存是由硬件完成的。
五、系统调用
1.系统调用的作用
应用程序通过系统调用来请求操作系统的服务。系统中各类共享资源由操作系统统一管理,用户程序中与资源有关的操作都要通过系统调用来让操作系统帮忙完成,可以保证系统的安全与稳定,防止用户非法操作。
2.系统调用的运行环境
系统调用涉及资源、进程管理,所以它一定运行在核心态来执行某些特权指令,用户可用陷入指令(trap内中断)来请求系统调用。
3.系统调用分类
如(1)设备管理(2)文件管理(3)进程控制(4)进程通信(5)内存管理
凡是跟资源有关的操作一定要进行系统调用,要学会如何判断。
4.系统调用与库函数
库函数的底层其实也是系统调用,只是封装起来了(如创建一个文件夹) ,有的库函数不涉及系统调用(如取绝对值)。
5.系统调用背后的过程
(1)传递系统调用参数
(2)执行陷入指令(用户态)
(3)执行系统调用相应服务程序(核心态)
(4)返回用户程序
发出系统调用请求是在用户态,而系统调用的处理是在核心态下的。
陷入指令是唯一一个只能在用户态下执行,而不能在核心态下执行的。