1、作業系統,4-1 作業系統簡介 4-2 各類作業系統 4-3 CPU排班 4-4 記憶體管理 4-5 檔案系統 4-6 熱門作業系統介紹,4-1 作業系統簡介,電腦系統:硬體、作業系統、應用軟體、使用者作業系統:負責管理電腦裡的硬體及周邊設備,扮演介於使用者與電腦硬體的中間人,作業系統的主要工作,4-2 各類作業系統:主機型系統,手動操作階段 使用者得熟悉計機的各部分細節及操作方法,操作麻煩又容易出錯,單工系統,4-2 各類作業系統:主機型系統,批次系統把相同或相似的工作集合成為一整批(batched)各個作業之間的轉接由監控程式自動操作,縮短手動操作緩慢所造成的CPU等待時間簡單的批次系統記
2、憶體配置,批次系統,多元程式規劃系統多元程式規劃的目的就是要增進CPU使用率程序的狀態:,各類作業系統:主機型系統(cont),程序狀態關係圖,進入,中斷,離開,I/O或事件等待,排班程式分派,I/O或事件完成,程序,處理器,如,等待使用者輸入指令,(程序:一個程式被載入記憶體中且執行的過程),處理器排班,CPU 首先為P0進行運算,P0進入等帶狀態時,OS提出中斷或系統呼叫,接著改為進行運算,如此來回轉換,各類作業系統:主機型系統(cont),分時系統採用時間觸發,CPU輪流計算各個程序,時間一到CPU就進行下一個程序的運算,多工系統,各類作業系統:主機型系統(cont),分時系統的特點:同
3、時性:可同時有若干個使用者連結到同一台計算機上進行運算獨立性:不同使用者之間不會相互干擾即時性:每一個使用者都可以即時得到計算機的回應,程序1,程序2,程序3,程序4,CPU,CPU,CPU,CPU,各類作業系統:個人電腦系統,個人系統的目標:增進使用者操作方便,並且提昇CPU的回應速度避免使用者等待個人電腦系統的演進:,早期:DOS文字指令,第一個圖形化介面:Mac OS,最多人使用:Windows,免付費作業系統:Linux,各類作業系統:多處理器系統,一個以上的處理器,彼此之間緊密地溝通合作,共享資源,共用時脈。多處理器系統可以增進效能,也因共用周邊設備, 共享電腦資源,所以較省空間。多
4、處理器系統中,多個應用程式共用記憶體等資源。多處理器系統擁有較好的容錯能力。,CPU,CPU,CPU,各類作業系統:分散式系統,每一台電腦是各自獨立的,並不共享資源或時脈,彼此之間依靠網路傳輸交換資料分散式系統的應用:Web Service,網路傳輸,各類作業系統:即時系統,即時系統:計算機要能即時回應外部事件的要求,於規定的時間內完成對該事件的處理,還要能控制所有的即時設備和工作能夠協調一致地執行即時系統的重點:,各類作業系統:手持系統,手持系統:個人數位助理,較手提式電腦輕薄短小。手持式系統的特點:,4-3 CPU排班,CPU排班:保持隨時都有一個程序在執行,提高CPU的使用率CPU排班的
5、五個決策時間點:,程序新產生時,程序從執行狀態變等待狀態(譬如有I/O要求),程序從執行狀態變就緒狀態(譬如有中斷發生時),程序從等待狀態變就緒狀態(譬如I/O要求得到回應),程序終止時,五個必須CPU排班的時間點,進入,中斷,離開,I/O或事件等待,排班程式分派,I/O或事件完成,評量CPU排班演算法好壞的標準,CPU排班 (cont),確保已經享有CPU資源的程序能夠一直用,不管其他程序的狀態,直到程序自己跳到其他非執行的狀態才進行排班 。,時時刻刻都要注意所有程序的狀態,如果有程序進入就緒狀態,那就要把已經就緒的程序跟正在使用CPU的程序互比較優先順序。優先順序較高的就能把對方踢去排隊。
6、,可搶先排班(preemptive),不可搶先排班(nonpreemptive),CPU排班演算法:先到先處理,先到先處理:採用先進先出的方式,服務先到的程序舉例:先到先處理之甘特圖:,先到先處理 (cont),各程序等待時間:若抵達先後順序改變如下:,先到先處理 (cont),則甘特圖如下所示:各程序的等待時間如下所示:,最短工作先處理,舉例 :甘特圖如下所示:,最短工作先處理 (cont),各程序的等待時間,最短工作先處理 (cont),不同的抵達順序及其平均等待時間,優先權排班,優先權如下:甘特圖如下:,依序循環排班,依序循環排班方式在使用時,先預設好經過多少時間CPU就該切換執行下一個
7、程序,也就是設定好間隔時間(time slice)。所有的程序放在先進先出的佇列裡面,,依序循環排班 (cont),範例:甘特圖:,4-4 記憶體管理,記憶體管理,基底暫存器(base register),記憶體,14500,326,CPU,邏輯位址,單一連續記憶體配置方式,記憶體被分成三個連續的區塊:作業系統存放、應用程式佔用、未使用,單一連續記憶體配置(cont),利用界線暫存器和基底暫存器來提供記憶體保護,CPU,記憶體,邏輯位址,是,實際位址,界線暫存器(limit register),基底暫存器,動態載入,動態載入是指常式(routine)只有在被呼叫的時候才會被載入,也就是說,將所
8、有的常式以可重定位載入的方式存放在磁碟空間內。主程式存放在記憶體中,執行時,若發現所需呼叫的常式不在記憶體內,便呼叫重疊定位連結程式,將需要的程式或資料庫入記憶體中。動態載入可以提供較大的彈性。,覆蓋,最主要的部分會一直放在記憶體中;只有在特定時候才需要用到的指令或資料,則只有被用到時才放在記憶體中,其他時候則被覆蓋掉。使用覆蓋的範例:編譯器。,置換,利用磁碟當作備份的儲存體,用以置換兩個程序,主記憶體,備份儲存體,程序P1,程序P2,置換 (cont),洋蔥皮演算法,附註:Paging system是虛擬記憶體管理的重要機制,它將一個程序的記憶體需求分割成大小相同的pages,以便更有效管理
9、。,4-5 檔案系統,檔案系統是指負責存取和管理檔案資料的軟體檔案的重要屬性:,檔案的基本操作,檔案的基本操作目錄結構必須支援的操作功能,建立檔案,寫入檔案,讀取檔案,刪除檔案,搜尋,建檔,刪除檔案,更改檔名,目錄結構:單層目錄,所有的檔案都裝在同一層目錄中同一個目錄裡不能有兩個相同的檔案名稱,目錄,檔案,目錄結構:雙層目錄,每個使用者的目錄夾裡的結構相似開啟檔案時,只會搜尋使用者所屬的目錄夾,主檔案目錄,使用者檔案目錄,路徑,絕對路徑:root/user1/Homework/hw1.doc相對路徑:/Homework/hw1.doc,4-6 熱門作業系統介紹,Linux創始人托瓦茲認為軟體免
10、費的比較好開放原始碼, 透過大家發現漏洞, 一起改善系統Linux的特點:真正意義上的多工、多用戶作業系統支援數十種檔案系統格式提供了先進的網路支援採用先進的記憶體管理機制,更加有效地利用實體記憶體開放原始碼,用戶可以自己對系統進行改進,熱門作業系統介紹 - Mac,第一個圖形化的作業系統,優異的使用者介面,漂亮的外型設計,針對影像圖片等工具有較好的支援程式,熱門作業系統介紹 Windows,最多人使用的作業系統,1990年推出Windows 3.0,分成DOS支脈及Windows NT,Windows NT代表New Technology,Windows XP代表eXPerience,2007年推出Vista,2009年推出Windows 7,