用户态和内核态的区别


应用程序需要从磁盘读取某个文件的数据,并不是直接从磁盘加载到应用内存中,而是:
1、先将数据从「磁盘」复制到「内核 Buffer」
2、再将数据从「内核 Buffer」复制到「用户 Buffer」

注:首先我们给他下个定义,这两个态是操作系统的运行级别。
然后我们知道,我们写的程序,最终运行的时候实际都会被编译、解释成一条一条的 CPU 指令被 CPU 执行

1、内核态与用户态介绍

1.1、操作系统的CPU状态

内核态(Kernel Mode):运行操作系统程序,操作硬件
用户态(User Mode):运行用户程序

1.2、指令划分

特权指令:只能由操作系统使用、用户程序不能使用的指令。
举例:启动I/O 内存清零 修改程序状态字 设置时钟 允许/禁止终端 停机
非特权指令:用户程序可以使用的指令。
举例:控制转移 算数运算 取数指令 访管指令(使用户程序从用户态陷入内核态)

1.3、特权级别

特权环:R0、R1、R2和R3
R0相当于内核态,
R3相当于用户态;
不同级别能够运行不同的指令集合;

1.4、CPU状态之间的转换

用户态—>内核态:唯一途径是通过中断、异常、陷入机制(访管指令)
内核态—>用户态:设置程序状态字PSW

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

2.1、权限不同

内核态是操作系统拥有最高权限的运行状态,可以访问系统的所有资源,而用户态只能访问受限的资源。

2.2、系统调用

在用户态下,应用程序需要通过系统调用来请求操作系统提供服务,而在内核态下,操作系统可以直接访问系统资源,不需要通过系统调用。

2.3、CPU指令

在内核态下,CPU可以执行所有的指令,而在用户态下,CPU只能执行受限的指令。

2.4、中断处理

在内核态下,操作系统可以响应所有的中断请求,而在用户态下,只能响应部分中断请求。

2.5、内存访问

在内核态下,操作系统可以访问所有的内存地址,而在用户态下,只能访问受限的内存地址。

2.6、运行环境

在内核态下,操作系统运行在内核空间,而在用户态下,应用程序运行在用户空间。

  • 9
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值