内核态(Kernel Mode)与用户态(User Mode)
生活随笔
收集整理的這篇文章主要介紹了
内核态(Kernel Mode)与用户态(User Mode)
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
內核態: CPU可以訪問內存所有數據, 包括外圍設備, 例如硬盤, 網卡. CPU也可以將自己從一個程序切換到另一個程序
用戶態: 只能受限的訪問內存, 且不允許訪問外圍設備. 占用CPU的能力被剝奪, CPU資源可以被其他程序獲取
為什么要有用戶態和內核態
由于需要限制不同的程序之間的訪問能力, 防止他們獲取別的程序的內存數據, 或者獲取外圍設備的數據, 并發送到網絡, CPU劃分出兩個權限等級 -- 用戶態 和 內核態
用戶態與內核態的切換
所有用戶程序都是運行在用戶態的, 但是有時候程序確實需要做一些內核態的事情, 例如從硬盤讀取數據, 或者從鍵盤獲取輸入等. 而唯一可以做這些事情的就是操作系統, 所以此時程序就需要先操作系統請求以程序的名義來執行這些操作.
這時需要一個這樣的機制: 用戶態程序切換到內核態, 但是不能控制在內核態中執行的指令
這種機制叫系統調用, 在CPU中的實現稱之為陷阱指令(Trap Instruction)
他們的工作流程如下:
轉載于:https://www.cnblogs.com/zemliu/p/3695503.html
總結
以上是生活随笔為你收集整理的内核态(Kernel Mode)与用户态(User Mode)的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: MVC的传递数据的方法
- 下一篇: Repository 仓储,你的归宿究竟