1 用户态和内核态的区别
下表主要从概念和cpu级别两方面阐述用户态和内核态的区别
用户态 | 内核态 | |
---|---|---|
概念 | 当进程在执行用户自己的代码时,则称其处于用户运行态(即用户态) | 但一个任务(进程)执行系统调用而陷入内核代码中执行时,我们称进程处于内核运行态(即内核态) |
cpu级别 | 处理器处于特权级最低的(3级)用户代码中执行 | 处理器处于特权级最高的(0级)内核代码中执行 |
2 用户态与内核态的联系
用户态转换为内核态主要分为主动和被动两种方式,其中主动方式包括系统调用,而被动方式包括异常和外围设备的中断。
- 系统调用:用户态进程主动要求切换到内核态的一种方式。
用户态进程通过系统调用申请使用操作系统提供的服务程序完成工作,比如:fork()实际上就是执行了一个创建新进程的系统调用。而系统调用的机制:其本质上还是使用了操作系统为用户特别开放的一个中断来实现。 - 异常:当cpu在执行运行在用户态下程序时,发生了某些事先不可知的异常,这时会触发由当前运行进程切换到处理此异常的内核相关程序中。如:缺页异常
- 外围设备的中断:当外围设备完成用户请求的操作后,会向CPU发出相应的中断信号,这时cpu会暂停执行下一条即将要执行的指令转而去执行与中断信号对应的处理程序,如果先前执行的指令是用户态下的程序,那么这个转换过程就完成了用户态到内核态的切换。如:硬盘读写操作完成,系统会切换到硬盘读写的中断处理程序中执行后续操作等。
3 用户态和内核态的在OS中所处的位置
内核态是OS对自己的保护机制,避免用户的误操作而导致系统崩溃的现象发生。
扩展
OS运行模式:在Inter x86:4种,Ring0~Ring3(Ring0最高,Ring3最低);而在Linux中,包括两种,Ring0和Ring3,无Ring1和Ring2.(其中,Ring0作为内核态,Ring3运行用户态,Ring3不能访问Ring0的地址空间,包括代码和数据)