1.操作系統管理硬件
真正操縱硬件的是操作系統,操作系統可以看成是應用程序和硬件之間的中間層。所有的應用程序對硬件的操作必須通過操作系統來完成,這樣做的目的是:首先,防止硬件被失控的應用程序所濫用;其次,操作系統提供統一的機制來控制這些復雜的底層硬件。
操作系統管理硬件
為了實現操作系統對硬件的操縱,操作系統引入了幾個抽象的概念。 文件是對IO設備的抽象、虛擬內存是對內存和磁盤IO的抽象、進程是對處理器、內存及IO設備的抽象 。
操作系統的抽象機制
2.進程的解釋
(1).以shell命令行中執行./hello命令為例進行說明,最開始的時候只有shell進程在運行,即shell在等待命令行的輸入。
命令輸入
(2).當通過shell進程加載hello進程時,shell進程通過系統調用來執行我們的請求。系統調用會將控制權從shell進程傳遞給操作系統,操作系統保存shell進程的 上下文 。然后,創建一個新的hello進程及其上下文。接著,將控制權轉交給新的hello進程。hello進程執行完成后,操作系統會恢復shell進程的上下文,并且將控制權交給shell進程,之后shell進程繼續等待下一個命令的輸入。
進程上下文切換
上下文:操作系統會跟蹤進程運行中所需要的所有狀態信息,這種狀態(例如:當前PC和寄存器的值、內存中的內容等)稱為上下文。
3.線程的解釋
現代操作系統中一個進程由多個線程組成,每個線程都運行在進程的上下文中,共享代碼和數據。
線程
4.虛擬內存
操作系統為每個進程提供了一個假象,即每個進程都在獨自占用整個內存空間。每個進程看到的內存都是一樣的,稱之為虛擬地址空間。
進程的虛擬地址空間
進程的虛擬地址空間:從下往上,地址是增大的。
第一個區域:用來存放程序的代碼和數據的,這個區域的內容是從可執行目標文件中加載而來的。對所有進程來說,代碼都是從固定的地址開始的;
第二個區域:堆heap,函數malloc所申請的地址空間就在這個堆中的,堆可以在運行時動態的擴展和收縮;
第三個區域:共享庫的存放區域,這個區域存放C語言的標準庫和數學庫這類共享庫的代碼和數據;
第四個區域:用戶棧,函數調用的本質就是壓棧;
第五個區域:為內核保留的區域,應用程序的代碼不能讀寫這個區域的數據,也不能直接調用內核中定義的函數,這個區域對應用程序不可見;
5.文件
Linux中一切皆文件,鍵盤、鼠標、磁盤、顯示器,甚至網絡這些都可以看成是文件,系統中所有的輸入和輸出都可以通過讀寫文件來完成。
"一切皆文件"
-
處理器
+關注
關注
68文章
19404瀏覽量
231111 -
計算機
+關注
關注
19文章
7534瀏覽量
88611 -
操作系統
+關注
關注
37文章
6889瀏覽量
123713 -
計算機系統
+關注
關注
0文章
289瀏覽量
24200 -
線程
+關注
關注
0文章
505瀏覽量
19750
發布評論請先 登錄
相關推薦
評論