操作系统—陷阱、中断、异常

在操作系统中,陷阱,中断和异常是常见的术语,它们贯穿操作系统学习的始终,这篇文章主要区分它们之间的不同。

陷阱

计算机有两种运行模式:用户态, 内核态。 其中操作系统运行在内核态,在内核态中,操作系统具有对所有硬件的完全访问权限,可以使机器运行任何指令;相反,用户程序运行在用户态,在用户态下,软件只能使用少数指令,它们并不具备直接访问硬件的权限。这就出现了问题,假如软件需要访问硬件或者需要调用内核中的函数该怎么办呢,这就是陷阱的作用了。陷阱指令可以使执行流程从用户态陷入内核(这也就是为什么叫做陷阱,而不是捕猎的陷阱)并把控制权转移给操作系统,使得用户程序可以调用内核函数和使用硬件从而获得操作系统所提供的服务,比如用视频软件放一个电影,视频软件就发出陷阱使用显示器和声卡从而访问硬件。

操作系统有很多系统调用接口供用程序调用。陷阱的发生时间是固定的,比如第一次用视频软件时,在加载视频时软件会向操作系统发送陷阱指令,第二次播放时,软件仍然会在同样的时刻发送陷阱指令。这一点是和中断的明显的差别之一。下面介绍中断。


中断

中断是由外部事件导致并且它发生的时间是不可预测的,这一点和陷阱不同。外部事件主要是指时钟中断,硬件中断等。由于CPU一次只能运行一条指令,所以在一个时刻只能有一个程序运行,但我们感觉在我们的计算机中明明可以同时运行很多程序啊,这是由于CPU在多个进程之间快速切换所导致的伪并行。如果某一个程序运行了足够长用完了分配给它的时间片,CPU决定切换到另一个进程运行,就会产生一个时钟中断,切换到下一个进程运行。

硬件中断顾名思义就是由硬件引起的中断,比如一个程序需要用户输入一个数据,但用户一直没有输入,操作系统决定是一直等待用户输入还是转而运行别的进程,一般情况是转而运行别的进程,如果用户的输入到来了,那么键盘驱动器会产生一个中断通知操作系统,操作系统保存正在运行的程序的状态,从而切换到原来的进程处理到来的数据。

所以中断发生是随机的且主要作用是完成进程间切换,从而支持CPU和设备之间的并行。
中断和异常的另一个重要差别是,CPU处理中断的过程中会屏蔽中断,不接受新的中断直到此次中断处理结束。而陷阱的发生并不屏蔽中断,可以接受新的中断。


异常

异常就是程序执行过程中的异常行为。比如除零异常,缓冲区溢出异常等。不同的操作系统定义了不同种类和数量的异常并且每个异常都有一个唯一的异常号,异常会扰乱程序的正常执行流程,所以异常是在CPU执行指令时本身出现的问题,比如除数为零而出现的除零异常。异常的产生表示程序设计不合理,所以在编程的时候要尽量避免异常的产生。


参考文章:

中断的系统调用   http://www.cnblogs.com/wuchanming/p/4020281.html

### 操作系统中断异常处理机制解释 #### 中断异常定义 中断(Interrupt)和异常(Exception)指明系统、处理器或当前执行程序(或任务)的某处出现了一个事件,此事件需要处理器立即进行处理[^3]。通常情况下,中断是在程序执行过程中随机发生的,主要响应来自硬件的信号,用于处理外部事件,例如外设的服务请求;而异常则是在处理器执行指令时检测到了错误条件所触发,如除零错误等。 #### 类型区分 对于异常而言,其被细分为三种不同类型:陷阱(Trap)、故障(Fault)以及中止(Abort)。这些类型的差异在于发生的原因及其后续处理方式的不同。当遇到特定情况下的非法操作或者预期内的操作失败时会触发陷阱;如果某个指令试图访问不存在的数据页面,则会产生页错误即属于故障的一种形式;至于中止则是更为严重的状况下才会产生的,它往往意味着遇到了不可恢复性的严重问题。 #### CPU状态转换 当中断异常发生之后,为了能够安全有效地完成相应的处理工作,CPU必须从用户模式转变为内核模式。这是因为操作系统在管理诸如进程调度、资源分配等工作时需要用到一些仅限于核心层使用的特权命令。这种转变使得OS获得了整个计算环境内的最高权限以便更好地协调各项活动并维持系统的稳定运行[^2]。 #### 流程概述 一旦接收到中断信号或是发生了异常情形后,系统将会保存现场信息——即将所有寄存器的内容复制到堆栈上以备将来恢复之需。接着调用对应的中断/异常服务例程(ISR),这个过程可能涉及到查找中断向量表来定位具体的ISR地址。最后,在完成了必要的处理逻辑之后再返回至原先被打断的地方继续往下执行未完成的任务[^1]。 ```python def handle_interrupt_or_exception(): save_context() # Save the current execution context to stack vector_table_address = get_vector_table_entry(interrupt_number) call_isr(vector_table_address) # Call Interrupt Service Routine based on address from table restore_context_and_resume_execution() ```
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值