1. 程式人生 > >多執行緒之間共享哪些資源?

多執行緒之間共享哪些資源?

同一程序間的執行緒究竟共享哪些資源呢,而又各自獨享哪些資源呢? 共享的資源有 a. 堆  由於堆是在程序空間中開闢出來的,所以它是理所當然地被共享的;因此new出來的都是共享的(16位平臺上分全域性堆和區域性堆,區域性堆是獨享的) b. 全域性變數 它是與具體某一函式無關的,所以也與特定執行緒無關;因此也是共享的 c. 靜態變數 雖然對於區域性變數來說,它在程式碼中是“放”在某一函式中的,但是其存放位置和全域性變數一樣,存於堆中開闢的.bss和.data段,是共享的 d. 檔案等公用資源  這個是共享的,使用這些公共資源的執行緒必須同步。Win32 提供了幾種同步資源的方式,包括訊號、臨界區、事件和互斥體。 獨享的資源有 a. 棧 棧是獨享的 b. 暫存器  這個可能會誤解,因為電腦的暫存器是物理的,每個執行緒去取值難道不一樣嗎?其實執行緒裡存放的是副本,包括程式計數器PC

執行緒共享的環境包括:程序程式碼段、程序的公有資料(利用這些共享的資料,執行緒很容易的實現相互之間的通訊)、程序開啟的檔案描述符、訊號的處理器、程序的當前目錄和程序使用者ID與程序組ID。

   程序擁有這許多共性的同時,還擁有自己的個性。有了這些個性,執行緒才能實現併發性。這些個性包括:
   1.執行緒ID
      每個執行緒都有自己的執行緒ID,這個ID在本程序中是唯一的。程序用此來標
   識執行緒。    2.暫存器組的值
      由於執行緒間是併發執行的,每個執行緒有自己不同的執行線索,當從一個線
   程切換到另一個執行緒上 時,必須將原有的執行緒的暫存器集合的狀態儲存,以便
   將來該執行緒在被重新切換到時能得以恢復。    3.執行緒的堆疊
      堆疊是保證執行緒獨立執行所必須的。
      執行緒函式可以呼叫函式,而被呼叫函式中又是可以層層巢狀的,所以執行緒
   必須擁有自己的函式堆疊, 使得函式呼叫可以正常執行,不受其他執行緒的影    響。
   4.錯誤返回碼
      由於同一個程序中有很多個執行緒在同時執行,可能某個執行緒進行系統呼叫
   後設置了errno值,而在該 執行緒還沒有處理這個錯誤,另外一個執行緒就在此時    被排程器投入執行,這樣錯誤值就有可能被修改。
      所以,不同的執行緒應該擁有自己的錯誤返回碼變數。

   5.執行緒的訊號遮蔽碼
      由於每個執行緒所感興趣的訊號不同,所以執行緒的訊號遮蔽碼應該由執行緒自
   己管理。但所有的執行緒都 共享同樣的訊號處理器。
   6.執行緒的優先順序
      由於執行緒需要像程序那樣能夠被排程,那麼就必須要有可供排程使用的參

   數,這個引數就是執行緒的 優先順序。