




版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進行舉報或認領
文檔簡介
1、2.7 2.7 線程的概念及其實現(xiàn)線程的概念及其實現(xiàn) 自從20世紀60年代提出進程概念以來,在操作系統(tǒng)中一直都是以進程作為能獨立運行的基本單位。直到80年代中期,人們又提出了比進程更小的能獨立運行的基本單位線程,用它來提高系統(tǒng)內(nèi)程序并發(fā)執(zhí)行的速度,減少系統(tǒng)開銷,從而可進一步提高系統(tǒng)的吞吐量。近幾年,線程概念已得到了廣泛應用,不僅在新推出的操作系統(tǒng)中,大多都已引入了線程概念,而且在新推出的數(shù)據(jù)庫管理系統(tǒng)和其它應用軟件中,也都紛紛引入了線程來改善系統(tǒng)的性能。2.7.1 2.7.1 線程的引入線程的引入 如果說,在操作系統(tǒng)中引入進程的目的,是為了使多個程序并發(fā)執(zhí)行,以改善資源利用率及提高系統(tǒng)的吞吐量
2、;那么,在操作系統(tǒng)中再引入線程則是為了減少程序并發(fā)執(zhí)行時所付出的時空開銷,使操作系統(tǒng)具有更好的并發(fā)性。 進程的兩個基本屬性: 進程是一個擁有資源的獨立單位; 進程同時又是一個獨立調(diào)度和分配的基本單位。 然而為使程序能并發(fā)執(zhí)行,系統(tǒng)還必須進行以下的一系列操作。 創(chuàng)建進程。系統(tǒng)在創(chuàng)建進程時,必須為之分配其所必需的、除CPU以外的所有資源。如內(nèi)存空間、I/O設備以及建立相應的PCB。 撤消進程。系統(tǒng)在撤消進程時,又必須先對這些資源進行回收操作,然后再撤消PCB。 進程切換。在對進程進行切換時,由于要保留當前進程的CPU環(huán)境和設置新選中進程的CPU環(huán)境,為此須花費許多CPU時間。2.7.2 2.7.2
3、 進程與線程的關系進程與線程的關系 線程具有許多傳統(tǒng)進程所具有的特征,故又稱為輕型進程(Light-Weight Process)或進程元;而把傳統(tǒng)的進程稱為重型進程(Heavy-Weight Process),它相當于只有一個線程的任務。在引入了線程的操作系統(tǒng)中,通常一個進程都有若干個線程,至少需要有一個線程。下面,我們從調(diào)度、并發(fā)性、系統(tǒng)開銷、擁有資源等方面,來比較線程與進程。1. 1. 調(diào)度調(diào)度 在傳統(tǒng)的操作系統(tǒng)中,擁有資源的基本單位和獨立調(diào)度的基本單位都是進程。而在引入線程的操作系統(tǒng)中,則把線程作為調(diào)度和分配的基本單位,而把進程作為擁有資源的基本單位,使傳統(tǒng)進程的兩個屬性分開,線程便能
4、輕裝運行,從而可顯著地提高系統(tǒng)的并發(fā)程度。在同一進程中,線程的切換不會引起進程的切換,在由一個進程中的線程切換到另一個進程中的線程時,將會引起進程的切換。2. 2. 并發(fā)性并發(fā)性 在引入線程的操作系統(tǒng)中,不僅進程之間可以并發(fā)執(zhí)行,而且在一個進程中的多個線程之間,亦可并發(fā)執(zhí)行,因而使操作系統(tǒng)具有更好的并發(fā)性,從而能更有效地使用系統(tǒng)資源和提高系統(tǒng)吞吐量。例如,在一個未引入線程的單CPU操作系統(tǒng)中,若僅設置一個文件服務進程,當它由于某種原因被阻塞時,便沒有其它的文件服務進程來提供服務。在引入了線程的操作系統(tǒng)中,可以在一個文件服務進程中,設置多個服務線程,當?shù)谝粋€線程等待時,文件服務進程中的第二個線程
5、可以繼續(xù)運行;當?shù)诙€線程阻塞時,第三個線程可以繼續(xù)執(zhí)行,依此類推,從而顯著地提高了文件服務的質(zhì)量以及系統(tǒng)吞吐量。3. 3. 擁有資源擁有資源 不論是傳統(tǒng)的操作系統(tǒng),還是設有線程的操作系統(tǒng),進程都是擁有資源的一個獨立單位,它可以擁有自己的資源。一般地說,線程自己不擁有系統(tǒng)資源(只有一些必不可少的資源),但它可以訪問其隸屬進程的資源。亦即,個進程的代碼段、數(shù)據(jù)段以及系統(tǒng)資源,如已打開的文件、I/O設備等,可供同一進程的所有線程共享。4. 4. 系統(tǒng)開銷系統(tǒng)開銷 由于在創(chuàng)建或撤消進程時,系統(tǒng)都要為之分配或回收資源,如內(nèi)存空間、I/O設備等。因而,操作系統(tǒng)所付出的開銷將顯著地大于在創(chuàng)建或撤消線程時的
6、開銷。類似地,在進行進程切換時,涉及到當前進程整個CPU環(huán)境的保存以及新被調(diào)度運行的進程的CPU環(huán)境的設置。而線程切換只需保存和設置少量寄存器的內(nèi)容,并不涉及存儲器管理方面的操作??梢?,進程切換的開銷也遠大于線程切換的開銷。此外,由于同一進程中的多個線程具有相同的地址空間,致使它們之間的同步和通信的實現(xiàn),也變得比較容易。在有的系統(tǒng)中,線程的切換、同步和通信都無需操作系統(tǒng)內(nèi)核的干預。2.7.3 2.7.3 線程的狀態(tài)及轉(zhuǎn)換線程的狀態(tài)及轉(zhuǎn)換 線程既然是進程中的一個執(zhí)行體,是系統(tǒng)進行調(diào)度的獨立單位,它就是一個動態(tài)的過程,因而,也就有生命周期,即由創(chuàng)建而產(chǎn)生,由調(diào)度而執(zhí)行,由撤銷而消亡。在線程的生命周
7、期中,它總是從一種狀態(tài)變遷到另一種狀態(tài)。與進程類似,在不同的操作系統(tǒng)中,線程的狀態(tài)有所不同,下面給出在Windows 2000/XP中的線程及其轉(zhuǎn)換圖,如圖2.17。初始化初始化備用備用終止終止就緒就緒運行運行轉(zhuǎn)換轉(zhuǎn)換等待等待創(chuàng)建和初始化創(chuàng)建和初始化線程對象線程對象重新初始化重新初始化放入就緒隊列放入就緒隊列選擇選擇執(zhí)行執(zhí)行被搶先被搶先搶先或時搶先或時間片結(jié)束間片結(jié)束執(zhí)行完成執(zhí)行完成描述表描述表切換切換等待完成等待完成等待對象等待對象句柄句柄換出換出內(nèi)核內(nèi)核堆棧堆棧 換入 內(nèi)核堆棧圖圖2.17 在在Windows 2000/XP中的線中的線程及其轉(zhuǎn)換圖程及其轉(zhuǎn)換圖2.7.4 2.7.4 線程調(diào)
8、度線程調(diào)度 線程調(diào)度與進程調(diào)度類似,原則上講,高優(yōu)先級的線程比低優(yōu)先級的線程有更多的運行機會,當?shù)蛢?yōu)先級的線程在運行時,被喚醒的或結(jié)束I/O等待的高優(yōu)先級線程立即搶占CPU并開始運行,如果線程具有相同的優(yōu)先級,則通過輪轉(zhuǎn)來搶占CPU資源。在Windows 2000/XP中,采用的是基于優(yōu)先級的搶占式多CPU調(diào)度策略。2.7.5 2.7.5 線程通信線程通信1. 1. 互斥鎖互斥鎖(mutex) (mutex) 2. 2. 條件變量條件變量3. 3. 信號量機制信號量機制 私用信號量私用信號量(private semaphore)(private semaphore)。 公用信號量公用信號量(public semaphore)(public semaphore)。2.7.6 2.7.6 多線程應用舉例多線程應用舉例 下面以客戶/服務器應用模式中服務器程序設計為例,來說明多線程技術(shù)
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預覽,若沒有圖紙預覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負責。
- 6. 下載文件中如有侵權(quán)或不適當內(nèi)容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 3主動拒絕煙酒與毒品 第1課時 教學設計-2024-2025學年道德與法治五年級上冊統(tǒng)編版
- 2024年高中生物 第六章 細胞的生命歷程 6.2 細胞的分化教學實錄 新人教版必修1
- 三農(nóng)村文化保護與傳承指南
- 建筑結(jié)構(gòu)抗震設計規(guī)范書
- 新員工入職培訓簡明教程
- 7 信息的交流傳播 教學設計-2024-2025學年科學六年級上冊教科版
- 1 物態(tài)變化與溫度 教學設計-2024-2025學年教科版物理八年級上冊
- 4日月山川(教學設計)-2024-2025學年統(tǒng)編版語文一年級上冊
- 醫(yī)院感染防控預案
- 10 奪取抗日戰(zhàn)爭和人民解放戰(zhàn)爭的勝利 教學設計-2023-2024學年道德與法治五年級下冊統(tǒng)編版
- 新課標(水平三)體育與健康《籃球》大單元教學計劃及配套教案(18課時)
- GA/T 761-2024停車庫(場)安全管理系統(tǒng)技術(shù)要求
- 大學生創(chuàng)新創(chuàng)業(yè)基礎(創(chuàng)新創(chuàng)業(yè)課程)完整全套教學課件
- 人教版小學數(shù)學四年級下冊第一單元測試卷附答案(共9套)
- (完整版)形式發(fā)票模版(國際件通用)
- GM∕T 0036-2014 采用非接觸卡的門禁系統(tǒng)密碼應用指南
- 部編版四年級道德與法治下冊第3課《當沖突發(fā)生》優(yōu)秀課件(含視頻)
- 游船安全生產(chǎn)事故調(diào)查處理及責任追究制度
- 辦公室裝修施工方案【完整版】
- 人教版小學體育一年級下冊教案(全冊)
- 薛湖礦施工組織設計
評論
0/150
提交評論