面试必备知识点,用户态和内核态的区别

三、特权级别


特权环:R0、R1、R2和R3

R0相当于内核态,R3相当于用户态;

不同级别能够运行不同的指令集合;

四、CPU状态之间的转换


**用户态—>内核态:**唯一途径是通过中断、异常、陷入机制(访管指令)

**内核态—>用户态:**设置程序状态字PSW

五、内核态与用户态的区别


    内核态与用户态是操作系统的两种运行级别,当程序运行在3级特权级上时,就可以称之为运行在用户态。因为这是最低特权级,是普通的用户进程运行的特权级,大部分用户直接面对的程序都是运行在用户态; 当程序运行在0级特权级上时,就可以称之为运行在内核态。 运行在用户态下的程序不能直接访问操作系统内核数据结构和程序。当我们在系统中执行一个程序时,大部分时间是运行在用户态下的,在其需要操作系统帮助完成某些它没有权力和能力完成的工作时就会切换到内核态(比如操作硬件)。 这两种状态的主要差别是 处于用户态执行时,进程所能访问的内存空间和对象受到限制,其所处于占有的处理器是可被抢占的 处于内核态执行时,则能访问所有的内存空间和对象,且所占有的处理器是不允许被抢占的。

六、通常来说,以下三种情况会导致用户态到内核态的切换


1、系统调用

这是用户态进程主动要求切换到内核态的一种方式,**用户态进程通过系统调用申请使用操作系统提供的服务程序完成工作。**比如前例中fork()实际上就是执行了一个创建新进程的系统调用。

而系统调用的机制其核心还是使用了操作系统为用户特别开放的一个中断来实现,例如Linux的int 80h中断。

用户程序通常调用库函数,由库函数再调用系统调用,因此有的库函数会使用户程序进入内核态(只要库函数中某处调用了系统调用),有的则不会。

2、异常

当CPU在执行运行在用户态下的程序时,发生了某些事先不可知的异常,这时会触发由当前运行进程切换到处理此异常的内核相关程序中,也就转到了内核态,比如缺页异常。

3、外围设备的中断

当外围设备完成用户请求的操作后,会向CPU发出相应的中断信号,这时CPU会暂停执行下一条即将要执行的指令转而去执行与中断信号对应的处理程序,

最后

金三银四到了,送上一个小福利!

4ciB2-1628237664408)]

[外链图片转存中…(img-lRo4lbRA-1628237664411)]

[外链图片转存中…(img-5EIhvcH7-1628237664412)]

经验分享 程序员 微信小程序 职场和发展