《計算機操作系統(第2版)》著重討論操作系統設計的基本概念、基本原理和典型技術,講述構造操作系統過程中可能面臨的種種問題及其解決辦法;介紹操作系統設計中的一些非常重要的進展,包括線程、實時系統、多處理器調度、進程遷移、分布式計算模式、分布式進程管理、中間件技術、微核技術、操作系統的安全性等。為了幫助讀者更好地理解操作系統的概念、原理和方法,更好地將理論與實際設計相結合,筆者選擇了目前具有代表性、典型性的操作系統Windows NT、UNIX、Linux作為實例貫穿全書,并專門介紹了一個小型操作系統--MINIX的設計與實現。目的是盡可能清晰、全面地向讀者展現較新的操作系統的設計原理與基本實現技術,以便讀者深入了解現在操作系統的全貌,為今后進行大型軟件研制與系統開發(fā)打下堅實基礎! 队嬎銠C操作系統(第2版)》可供大專院校計算機專業(yè)及相關專業(yè)的師生作為教材,也可供在計算機軟件企業(yè)和IT行業(yè)工作的科技工作者與管理者學習和參考。
操作系統是計算機系統中最關鍵的系統軟件,計算機系統愈復雜,操作系統的作用和地位就愈重要。
本書結合現在操作系統的設計并考慮操作系統的發(fā)展方向,著重討論操作系統設計的基本概念、基本原理和典型技術。全書共分12章,下面介紹各章內容組成。
第1章簡要介紹操作系統的基本概念、功能、發(fā)展歷史以及主要成就等。
第2章介紹了進程的概念,以及操作系統對進程進行控制和管理時采用的數據結構,還討論了與進程相關的線程等內容。
第3章介紹了在單一系統中并行處理的關鍵技術--互斥和同步機制。
第4章描述了死鎖的性質,并討論了解決死鎖問題的一些方法。
第5章討論了多種內存管理方法,并討論了用于支撐虛擬內存所需的硬件結構和操作系統用來管理虛擬內存的軟件方法。
第6章分析了各種不同的進程調度方法,包括實時調度策略等方面的內容。
第7章論述了操作系統對輸入/輸出設備的控制和管理,尤其是對系統性能影響較大的磁盤I/O的調度和控制。
第8章對文件的組織、存儲、使用和保護等方面的內容進行了講解。
第9章和第10章描述了分布式操作系統的一些關鍵設計領域,包括Client/Server結構,用于消息傳遞和遠程過程調用的分布式通信機制、分布式進程遷移、中間件以及解決分布式互斥和死鎖問題的原理與技術。
第11章簡要討論了保證操作系統安全性的相關理論和方法。
第12章以小型操作系統MINIX為例,用解釋性的方式介紹了MINIX設計和實現的具體過程,以期達到理論聯系實際,學以致用,突出實踐性的目的。
本書由何炎祥、李飛、李寧共同編寫,何炎祥統編了全書。在編寫過程中得到了武漢大學計算機學院領導和同事們的熱情幫助,清華大學出版社為本書的出版給予了大力支持,文中還參考、引用了國內外一些專家學者的論著和研究工作,以及一些公司的產品介紹,在此一并表示誠摯的感謝。
隨著操作系統技術的發(fā)展,本書在前一版的基礎上,對部分內容進行了修訂和改編,以適應教學需要。
限于水平,書中錯誤難免,敬請讀者不吝賜教。
編 者
2011年2月