成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

操作系統中的進程與線程

開發 開發工具
在傳統的操作系統中,進程擁有獨立的內存地址空間和一個用于控制的線程。但是,現在的情況更多的情況下要求在同一地址空間下擁有多個線程并發執行。因此線程被引入操作系統。

為什么需要線程?

如果非要說是為什么需要線程,還不如說為什么需要進程中還有其它進程。這些進程中包含的其它迷你進程就是線程。

線程之所以說是迷你進程,是因為線程和進程有很多相似之處,比如線程和進程的狀態都有運行,就緒,阻塞狀態。這幾種狀態理解起來非常簡單,當進程所需的資源沒有到位時會是阻塞狀態,當進程所需的資源到位時但CPU沒有到位時是就緒狀態,當進程既有所需的資源,又有CPU時,就為運行狀態。

下面我們來看一個具體的例子:

就拿我寫博客的LiveWriter來說,LiveWriter需要監聽我打字輸入的狀態,還需要每隔5分鐘對草稿進行自動保存。假設如果這個進程只有一個線程的話,那么當對草稿進行保存時,因為此時需要訪問硬盤,而訪問硬盤的時間線程是阻塞狀態的,這時我的任何輸入都會沒有響應,這種用戶體驗是無法接受的,或許我們可以通過鍵盤或者鼠標的輸入去中斷保存草稿的過程,但這種方案也并不討好。而使用多線程,每個線程僅僅需要處理自己那一部分應該完成的任務,而不用去關心和其它線程的沖突。因此簡化了編程模型。如圖1所示。

1

圖1.兩條線程滿足各自的功能

更具體的說,線程的好處如下:

1.在很多程序中,需要多個線程互相同步或互斥的并行完成工作,而將這些工作分解到不同的線程中去無疑簡化了編程模型。

2.因為線程相比進程來說,更加的輕量,所以線程的創建和銷毀的代價變得更小。

3.線程提高了性能,雖然線程宏觀上是并行的,但微觀上卻是串行。從CPU角度線程并無法提升性能,但如果某些線程涉及到等待資源(比如IO,等待輸入)時,多線程允許進程中的其它線程繼續執行而不是整個進程被阻塞,因此提高了CPU的利用率,從這個角度會提升性能。

4.在多CPU或多核的情況下,使用線程不僅僅在宏觀上并行,在微觀上也是并行的。

這里值得注意的是,上面的兩個線程如果改成兩個進程,那么達不到所要的效果,因為進程有自己獨立的內存地址空間,而線程共享進程的內存地址空間。

經典線程模型

另一個看進程和線程的角度是進程模型基于兩類不同的概念:資源的組織和執行。在過去沒有線程的操作系統中,資源的組織和執行都是由進程完成的。但區分這兩者很多時候需要加以區分,這也是為什么需要引入線程。

進程是用于組織資源的單位,進程將相關的資源組織在一起,這些資源包括:內存地址空間,程序,數據等,將這些以進程的形式組織起來可以使得操作系統管理這些資源更為容易。

而線程,是每一個進程中執行的一個條線。線程雖然共享進程中的大多數資源,但線程也需要自己的一些資源,比如:用于標識下一條執行指令的程序計數器,一些容納局部變量的寄存器,以及用于表示執行的歷史的棧。

總而言之:進程是組織資源的最小單位,而線程是安排CPU執行的最小單位。

其實在一個進程中多個線程并行和在操作系統中多個進程并行非常類似,只是線程共享的是地址空間,而進程共享的是物理內存,打印機,鍵盤等資源……

每一個進程和線程所獨自占有的資源如表1所示。

進程占有的資源 線程占有的資源
地址空間
全局變量
打開的文件
子進程
信號量
賬戶信息

寄存器
狀態
程序計數器

表1.進程和線程所獨占的資源

其中,線程可以共享進程獨占的資源。

我們常用的術語“多線程”一般指的是在同一個進程中多個線程的并發執行。如圖2所示。

2

圖2.沒有多線程的系統一個進程只能由一個線程

在多線程的進程中,每個線程輪流使用CPU,因此實際上線程并不是并行的,但從宏觀上看,是并行的。

在多線程模型中,每一個進程初始創建時只有一個線程。這個線程可以通過調用系統的庫函數去創建其它線程。線程創建的線程并必須要為其指定地址,因為新的線程自動在創建它的地址空間內工作。雖然一個線程可以創建另一個線程,但通常來講,線程之間是并列的,并不存在層級關系。

當一個進程完成其工作后,可以通過調用系統庫函數進行銷毀。

操作系統實現線程的幾種模式

在操作系統中,線程可以實現在用戶模式下,也可以實現在內核模式下,也可以兩者結合實現。

線程實現在用戶空間下

當線程在用戶空間下實現時,操作系統對線程的存在一無所知,操作系統只能看到進程,而不能看到線程。所有的線程都是在用戶空間實現。在操作系統看來,每一個進程只有一個線程。過去的操作系統大部分是這種實現方式,這種方式的好處之一就是即使操作系統不支持線程,也可以通過庫函數來支持線程。

在這種模式下,每一個進程中都維護著一個線程表來追蹤本進程中的線程,這個表中包含表1中每個線程獨占的資源,比如棧,寄存器,狀態等,如圖3所示。

3

圖3.在用戶空間中實現線程

這種模式當一個線程完成了其工作或等待需要被阻塞時,其調用系統過程阻塞自身,然后將CPU交由其它線程。

這種的模式的好處,首先,是在用戶空間下進行進程切換的速度要遠快于在操作系統內核中實現。其次,在用戶空間下實現線程使得程序員可以實現自己的線程調度算法。比如進程可以實現垃圾回收器來回收線程。還有,當線程數量過多時,由于在用戶空間維護線程表,不會占用大量的操作系統空間。

有好處就有壞處,這種模式最致命的缺點也是由于操作系統不知道線程的存在,因此當一個進程中的某一個線程進行系統調用時,比如缺頁中斷而導致線程阻塞,此時操作系統會阻塞整個進程,即使這個進程中其它線程還在工作。還有一個問題是假如進程中一個線程長時間不釋放CPU,因為用戶空間并沒有時鐘中斷機制,會導致此進程中的其它線程得不到CPU而持續等待。

線程實現在操作系統內核中

在這種模式下,操作系統知道線程的存在。此時線程表存在操作系統內核中,如圖4所示。

4

圖4.線程在操作系統內核中實現

在這種模式下,所有可能阻塞線程的調用都以系統調用(System Call)的方式實現,相比在用戶空間下實現線程造成阻塞的運行時調用(System runtime call)成本會高出很多。當一個線程阻塞時,操作系統可以選擇將CPU交給同一進程中的其它線程,或是其它進程中的線程,而在用戶空間下實現線程時,調度只能在本進程中執行,直到操作系統剝奪了當前進程的CPU。

因為在內核模式下實現進程的成本更高,一個比較好的做法是另線程回收利用,當一個線程需要被銷毀時,僅僅是修改標記位,而不是直接銷毀其內容,當一個新的線程需要被創建時,也同樣修改被“銷毀”的線程其標記位即可。

這種模式下同樣還是有一些弊端,比如接收系統信號的單位是進程,而不是線程,那么由進程中的哪一個線程接收系統信號呢?如果使用了表來記錄,那么多個線程注冊則通過哪一個線程處理系統信號?

混合模式

還有一種實現方式是將上面兩種模式進行混合,用戶空間中進程管理自己的線程,操作系統內核中有一部分內核級別的線程,如圖5所示。

5

圖5.混合模式

在這種模式下,操作系統只能看到內核線程。用戶空間線程基于操作系統線程運行。因此,程序員可以決定使用多少用戶空間線程以及操作系統線程,這無疑具有更大的靈活性。而用戶空間線程的調度和前面所說的在用戶空間下執行實現線程是一樣的,同樣可以自定義實現。

原文鏈接:http://www.cnblogs.com/CareySon/archive/2012/05/04/ProcessAndThread.html

【編輯推薦】
責任編輯:彭凡 來源: 博客園
相關推薦

2010-04-22 13:56:21

Aix操作系統

2021-08-12 14:49:44

操作系統線程進程

2019-06-26 09:10:07

操作系統調度算法

2010-04-14 13:59:45

Unix操作系統

2010-04-16 18:19:32

Unix操作系統

2023-03-13 14:08:00

系統抽象操作系統大型系統

2010-04-09 17:25:13

Unix操作系統

2010-04-14 15:58:25

Unix操作系統

2010-04-19 09:08:20

Unix操作系統

2010-04-19 16:47:40

Unix操作系統

2010-04-14 13:20:29

Unix操作系統

2010-04-14 16:45:15

Unix操作系統

2010-04-30 17:27:59

Unix操作系統

2021-04-19 09:27:03

Java線程操作系統

2009-12-15 18:27:51

Linux操作系統

2025-04-03 01:45:00

2025-05-12 09:12:59

2010-04-14 14:52:14

Unix操作系統

2020-03-10 19:34:08

CPU虛擬化調度

2010-04-22 15:14:12

Aix操作系統
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 一区二区三区国产好 | www在线视频 | 亚洲成人精选 | 97色在线视频 | av一级一片| 玖玖免费 | 久久精品在线免费视频 | 国产乱精品一区二区三区 | 一区二区三区在线免费观看 | 一区二区三区精品在线视频 | av中文字幕在线观看 | 国产精品www | 午夜男人的天堂 | 亚洲一区二区三区桃乃木香奈 | 日韩在线看片 | 日韩中文一区二区三区 | 中文成人在线 | 久久久久久亚洲精品 | 成人精品毛片 | 黄色一级毛片 | 亚洲精品乱码8久久久久久日本 | 日韩精品免费一区二区在线观看 | 久久精品国产久精国产 | 亚洲交性 | 亚洲高清在线观看 | 99久久久久 | 国产亚洲精品美女久久久久久久久久 | 一级片免费网站 | 在线国产视频 | 精品一区二区三区中文字幕 | 日本一区二区高清不卡 | 免费看国产精品视频 | 午夜精品一区二区三区在线视频 | 久久在线免费 | 亚洲三级免费看 | 欧美一级片黄色 | 国产伦精品一区二区三区四区视频 | 久久新| 男人天堂社区 | 国产在线观看av | 国产高清无av久久 |