用户态 VS 内核态

1 用户态和内核态的区别

下表主要从概念和cpu级别两方面阐述用户态和内核态的区别

用户态内核态
概念当进程在执行用户自己的代码时,则称其处于用户运行态(即用户态)但一个任务(进程)执行系统调用而陷入内核代码中执行时,我们称进程处于内核运行态(即内核态)
cpu级别处理器处于特权级最低的(3级)用户代码中执行处理器处于特权级最高的(0级)内核代码中执行

2 用户态与内核态的联系

用户态转换为内核态主要分为主动和被动两种方式,其中主动方式包括系统调用,而被动方式包括异常和外围设备的中断。

  1. 系统调用:用户态进程主动要求切换到内核态的一种方式。
    用户态进程通过系统调用申请使用操作系统提供的服务程序完成工作,比如:fork()实际上就是执行了一个创建新进程的系统调用。而系统调用的机制:其本质上还是使用了操作系统为用户特别开放的一个中断来实现。
  2. 异常:当cpu在执行运行在用户态下程序时,发生了某些事先不可知的异常,这时会触发由当前运行进程切换到处理此异常的内核相关程序中。如:缺页异常
  3. 外围设备的中断:当外围设备完成用户请求的操作后,会向CPU发出相应的中断信号,这时cpu会暂停执行下一条即将要执行的指令转而去执行与中断信号对应的处理程序,如果先前执行的指令是用户态下的程序,那么这个转换过程就完成了用户态到内核态的切换。如:硬盘读写操作完成,系统会切换到硬盘读写的中断处理程序中执行后续操作等。

3 用户态和内核态的在OS中所处的位置

内核态是OS对自己的保护机制,避免用户的误操作而导致系统崩溃的现象发生。
在这里插入图片描述

扩展

OS运行模式:在Inter x86:4种,Ring0~Ring3(Ring0最高,Ring3最低);而在Linux中,包括两种,Ring0和Ring3,无Ring1和Ring2.(其中,Ring0作为内核态,Ring3运行用户态,Ring3不能访问Ring0的地址空间,包括代码和数据)

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值