一叔壤、進程與線程的區(qū)別:
1、進程是資源分配的最小單位凳兵,線程是程序執(zhí)行的最小單位(資源調(diào)度的最小單位)
2百新、進程有自己的獨立地址空間,每啟動一個進程庐扫,系統(tǒng)就會為它分配地址空間饭望,建立數(shù)據(jù)表來維護代碼段、堆棧段和數(shù)據(jù)段形庭,這種操作非常昂貴铅辞。
而線程是共享進程中的數(shù)據(jù)的,使用相同的地址空間萨醒,因此CPU切換一個線程的花費遠比進程要小很多斟珊,同時創(chuàng)建一個線程的開銷也比進程要小很多。
3富纸、線程之間的通信更方便囤踩,同一進程下的線程共享全局變量旨椒、靜態(tài)變量等數(shù)據(jù),而進程之間的通信需要以通信的方式(IPC)進行堵漱。不過如何處理好同步與互斥是編寫多線程程序的難點综慎。
4、但是多進程程序更健壯勤庐,多線程程序只要有一個線程死掉示惊,整個進程也死掉了,而一個進程死掉并不會對另外一個進程造成影響愉镰,因為進程有自己獨立的地址空間米罚。
參考:https://www.cnblogs.com/zhehan54/p/6130030.html
二、進程與線程的資源:
1丈探、堆與棧
堆: 是大家共有的空間录择,分全局堆和局部堆。全局堆就是所有沒有分配的空間类嗤,局部堆就是用戶分配的空間糊肠。堆在操作系統(tǒng)對進程初始化的時候分配,運行過程中也可以向系統(tǒng)要額外的堆遗锣,但是記得用完了要還給操作系統(tǒng)货裹,要不然就是內(nèi)存泄漏。
棧:是個線程獨有的精偿,保存其運行狀態(tài)和局部自動變量的弧圆。棧在線程開始的時候初始化,每個線程的棻恃剩互相獨立搔预,因此,棧是 thread safe的叶组。操作系統(tǒng)在切換線程的時候會自動的切換棧拯田,就是切換 SS/ESP寄存器甩十。棿樱空間不需要在高級語言里面顯式的分配和釋放。
2侣监、其他
線程共享的環(huán)境包括:進程代碼段鸭轮、進程的公有數(shù)據(jù)(利用這些共享的數(shù)據(jù),線程很容易的實現(xiàn)相互之間的通訊)橄霉、進程打開的文件描述符窃爷、信號的處理器、進程的當前目錄和進程用戶ID與進程組ID。
進程擁有這許多共性的同時按厘,還擁有自己的個性医吊。有了這些個性,線程才能實現(xiàn)并發(fā)性刻剥。這些個性包括:
1.線程ID
每個線程都有自己的線程ID遮咖,這個ID在本進程中是唯一的。進程用此來標
識線程造虏。
2.寄存器組的值
由于線程間是并發(fā)運行的,每個線程有自己不同的運行線索麦箍,當從一個線
程切換到另一個線程上時漓藕,必須將原有的線程的寄存器集合的狀態(tài)保存,以便
將來該線程在被重新切換到時能得以恢復挟裂。
3.線程的堆棧
堆棧是保證線程獨立運行所必須的享钞。
線程函數(shù)可以調(diào)用函數(shù),而被調(diào)用函數(shù)中又是可以層層嵌套的诀蓉,所以線程
必須擁有自己的函數(shù)堆棧栗竖,使得函數(shù)調(diào)用可以正常執(zhí)行,不受其他線程的影
響渠啤。
4.錯誤返回碼
由于同一個進程中有很多個線程在同時運行狐肢,可能某個線程進行系統(tǒng)調(diào)用
后設(shè)置了errno值,而在該線程還沒有處理這個錯誤沥曹,另外一個線程就在此時
被調(diào)度器投入運行份名,這樣錯誤值就有可能被修改。
所以妓美,不同的線程應(yīng)該擁有自己的錯誤返回碼變量僵腺。
5.線程的信號屏蔽碼
由于每個線程所感興趣的信號不同,所以線程的信號屏蔽碼應(yīng)該由線程自
己管理壶栋。但所有的線程都共享同樣的信號處理器辰如。
6.線程的優(yōu)先級
由于線程需要像進程那樣能夠被調(diào)度,那么就必須要有可供調(diào)度使用的參
數(shù)贵试,這個參數(shù)就是線程的優(yōu)先級琉兜。
參考:https://blog.csdn.net/shuilan0066/article/details/7683315
3、進程與線程的同步
進程:無名管道锡移、有名管道呕童、信號、共享內(nèi)存淆珊、消息隊列夺饲、信號量
進程:互斥量、讀寫鎖、自旋鎖往声、線程信號擂找、條件變量
作者:小雨啟明
鏈接:http://www.reibang.com/p/2dc01727be45
來源:簡書
簡書著作權(quán)歸作者所有,任何形式的轉(zhuǎn)載都請聯(lián)系作者獲得授權(quán)并注明出處浩销。