操作系統複習筆記

来源:http://www.cnblogs.com/liushengchieh/archive/2017/07/12/7154172.html
-Advertisement-
Play Games

操作系統複習 第1章 操作系統概論 定義:管理系統資源、控製程序執行、改善人機界面、提供各種服務,併合理組織電腦工作流程和為用戶方便有效的使用電腦提供良好運行環境的一種系統軟體。 功能:處理器管理、存儲管理、設備管理、文件管理、聯網和通信管理 特性:併發性、共用性(1.透明資源共用 2.獨占資源 ...


操作系統複習

第1章 操作系統概論

定義:管理系統資源、控製程序執行、改善人機界面、提供各種服務,併合理組織電腦工作流程和為用戶方便有效的使用電腦提供良好運行環境的一種系統軟體。
功能:處理器管理、存儲管理、設備管理、文件管理、聯網和通信管理
特性:併發性、共用性(1.透明資源共用 2.獨占資源共用)、非同步性
分類:批處理操作系統、分時操作系統、實時操作系統

第2章 處理器管理

進程定義:進程是具有獨立功能的程式在某個數據集合上的一次運行活動,也是操作系統進行資源分配和保護的基本單位。
進程狀態和轉換:p73
三態模型:運行態、就緒態、等待態
五態模型:新建態、終止態提出的原因?
要求會畫圖,解釋某些轉換是不存在的。

引入多線程的動機:減少程式併發執行時所付出的時空開銷,使得併發顆粒度更細、併發性更好。
線程的優點:快速線程切換、通信易於實現、減少管理開銷、併發程度提高

PCB(Process Control Block)進程式控制制塊:進程存在的唯一標識,是操作系統用來記錄和刻畫進程狀態及環境信息的數據結構,是進程動態特征的彙集,也是操作系統掌握進程的唯一資料結構和管理進程的主要依據。p75

TCB的概念?
動態/靜態 優先順序?

處理器調度:p101 例題

  1. 先來先服務演算法
  2. 最短作業優先演算法(概念)
  3. 最短剩餘時間優先演算法
  4. 最高響應比優先演算法(概念)

第3章 同步、通信與死鎖

佰恩斯坦條件?Bernstein(簡答)

死鎖:一組進程因爭奪資源陷入永遠等待的狀態。
饑餓:一個可運行進程由於其他進程總是優先於它,而被調度程式無限期的拖延而不能被執行。

進程同步:為完成共同任務的併發進程基於某個條件來協調其活動,因為需要在某些位置上排定執行的先後次序而等待、傳遞信號或消息所產生的協作制約關係。

臨界區:併發進程中與共用變數有關的程式段。
臨界資源:共用變數所代表的資源,即一次僅能供一個進程使用的資源。
臨界區調度的三個原則(互斥使用,有空讓進;忙則要等,有限等待;擇一而入,演算法可行。):

  1. 一次至多只有一個進程進入臨界區內執行。
  2. 如果已有進程在臨界區中,試圖進入此臨界區的其他進程應等待。
  3. 進入臨界區內的進程應在有限時間內退出,以便讓等待隊列中的一個進程進入。

實現臨界區管理的軟體演算法:
分析

  1. 是否會出問題?
  2. 何時出?

實現臨界區管理的硬體設施:

  1. 關中斷
  2. 測試並設置指令
  3. 對換指令

信號量與PV操作:p134

pv操作定義(一元、一般)?
綜合題:

  1. 5位哲學家就餐問題 (無死鎖解法) p139
  2. 生產者-消費者問題(多對多、多緩衝區)p140
  3. 讀者-寫者問題 p141
  4. 理髮師問題 p142
  5. 和尚打水

死鎖

定義:如果一個進程集合中的每個進程都在等待只能由此集合中的其他進程才能引發的事件,而無限期的陷入僵持的局面。
產生的條件:

  1. 互斥條件
  2. 占有和等待條件
  3. 不剝奪條件
  4. 迴圈等待條件

死鎖避免:綜合題15分
銀行家演算法的數據結構 p163
演算法描述:

  1. T0時刻的安全序列
  2. 進程P1請求資源(能否滿足?為什麼?)

第4章 存儲管理

程式的鏈接種類:(填空)

  1. 靜態鏈接
  2. 動態鏈接
  3. 運行時鏈接

靜態地址重定位:由裝載程式實現裝載代碼的載入和地址轉換,把它裝入分配給進程的記憶體指定區域,其中的所有邏輯地址修改成記憶體物理地址。
動態地址重定位:由裝載程式實現裝載代碼模塊的載入,把它裝入分配給進程的記憶體指定區域,但對鏈接程式處理過的應用程式的邏輯地址則不做任何修改,程式記憶體起始地址被置入硬體專用寄存器——重定位寄存器。程式執行過程中,每當cpu引用記憶體地址(訪問程式和數據)時,由硬體截取此邏輯地址,併在它被髮送到記憶體之前加上重定位寄存器的值,以便實現地址轉換。

分頁存儲管理 p206
概念:

  1. 頁面
  2. 頁框
  3. 邏輯地址
  4. 記憶體頁框表
  5. 頁表

分頁/分段 動態鏈接庫的實現原理?(說明+畫圖)

綜合題:

  1. 給出邏輯地址,求物理地址?(畫圖)
  2. 給出邏輯地址、頁面大小,計算物理地址?

分段和分頁的比較(簡答):
分段是信息的邏輯單位,由源程式的邏輯結構及含義所決定,是用戶可見的,段長由用戶根據需要來確定,段起始地址可從任何記憶體地址開始。在分段方式中,源程式(短號、段內位移)經鏈接裝配後仍保持二維(地址)結構,引入目的是滿足用戶模塊化程式設計的需要。
分頁是信息的物理單位,與源程式的邏輯結構無關,是用戶不可見的,頁長由系統(硬體)確定,頁面只能從頁大小的整數倍位置開始。在分頁方式中,源程式(頁號、頁內位移)經鏈接裝配後變成一維(地址)結構,引入目的是實現離散分配並提高記憶體利用率。

缺頁中斷率 p223
概念:不成功訪問次數?
畫圖,求缺頁中斷率? p229

第5章 設備管理

I/O控制方式:(填空)

  1. 輪詢方式
  2. 中斷方式
  3. DMA方式
  4. 通道方式

緩衝技術:
單緩衝 p265
雙緩衝 p266

搜查定位:(例題、簡答)p270

  • 先來先服務演算法
  • 最短查找時間優先演算法
  • 掃描演算法
  • 電梯調度演算法
  • 迴圈掃描演算法

參考書目:

-《操作系統教程(第五版)》費翔林、駱斌著 高等教育出版社


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • squid作用 1正向代理 標準的代理緩衝伺服器,須在每一個內部主機的瀏覽器上明確指明代理伺服器的IP地址和埠號。 透明代理緩衝伺服器,代理操作對客戶端的瀏覽器是透明的(即不需指明代理伺服器的IP和埠)Iptables或者Ipchains實現 參考http://os.51cto.com/art/ ...
  • 編譯內核4.12 第一步 我們首先應該下載kernel的軟體包,可以點擊https://www.kernel.org/進行下載 第二步 然後解壓linux 對應版本的軟體包到到當前目錄,當前本人所在目錄為用戶家目錄 tar xvf linux 4.12.tar.xz 第三步 cd切換進解壓後的目錄中 ...
  • 問題現象: Tomcat(8.5.13)部署了SuperMap iServer,併發用戶在100左右。系統運行一段時間後,服務崩潰。異常提示 問題分析: 1、看到日誌中的提示信息後,認為是系統記憶體不足導致的。於是在伺服器上添加了監控腳本(如下圖),每1s記錄一次系統記憶體和tomcat記憶體。 監控一段 ...
  • 這個問題在剛學Linux遇到的,centOS7的網卡啟動不起來,導致建不了集群。如下圖沒有ifconf-env33網卡的IP 還有下麵這個圖》》》 如果你遇到了,呵呵呵,迷之微笑。 虛擬機網卡沒起來,這個問題比較尷尬,我只能告訴你解決方法。。 一、關閉電腦。真的,小編調了一天錯,在網上各種找解決辦 ...
  • linux入侵分析,重裝ssh,配置ssh黑白名單和管理IP ...
  • Let's Encrypt免費SSL證書的出現,也會對傳統提供付費SSL證書服務的商家有不小的打擊。到目前為止,Let's Encrypt獲得IdenTrust交叉簽名,這就是說可以應用且支持包括FireFox、Chrome在內的主流瀏覽器的相容和支持,雖然目前是公測階段,但是也有不少的用戶在自有網 ...
  • 一、正則表達式 1、匹配字元的類型 [a-z]:小寫字母 [A-Z]:大寫字母 [a-Z]:小或大寫字母 [0-9]:數字 [a-zA-Z0-9]:表示匹配一個為字母或數字的字元 . :匹配1個任意字元,空格除外 [0-f]:16進位數 abc | def:abc或def a (bc | de) f ...
  • 本文所選的例子來自於《Advanced Bash-scripting Gudie》一書,譯者 楊春敏 黃毅 在改編這個腳本的時候,我的考慮點主要有以下: 1. 所傳的參數是不是要排除非整數的情況? 非整數的情況第一次我用echo $i | sed '/s/^[0-9]*$/''/g' && echo ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...