sem_t

C語言中,信號量的數據類型為結構sem_t,它本質上是一個長整型的數。

基本介紹

  • 中文名:sem_t
  • 外文名:extern int sem_init __P
初始化信號量,相關套用,使用步驟,舉例說明,

初始化信號量

它的原型為: extern int sem_init __P ((sem_t *__sem, int __pshared, unsigned int __value));
頭檔案為: #include <semaphore.h>
sem為指向信號量結構的一個指針;
pshared不為0時此信號量在進程間共享,否則只能為當前進程的所有執行緒共享;
value給出了信號量的初始值。
函式sem_post( sem_t *sem )用來增加信號量的值當有執行緒阻塞在這個信號量上時,調用這個函式會使其中的一個執行緒不再阻塞,選擇機制同樣是由執行緒的調度策略決定的。
函式sem_wait( sem_t *sem )被用來阻塞當前執行緒直到信號量sem的值大於0,解除阻塞後將sem的值減一,表明公共資源經使用後減少。
函式sem_trywait ( sem_t *sem )是函式sem_wait()的非阻塞版本,它直接將信號量sem的值減一。
函式sem_destroy(sem_t *sem)用來釋放信號量sem。

相關套用

(1)信號量用sem_init函式創建的,下面是它的說明:
#include<semaphore.h>
int sem_init (sem_t *sem, int pshared, unsigned int value);
這個函式的作用是對由sem指定的信號量進行初始化,設定好它的共享選項,並指定一個整數類型的初始值。pshared參數控制著信號量的類型。如果 pshared的值是0,就表示它是當前進程的局部信號量;否則,其它進程就能夠共享這個信號量。只對不讓進程共享的信號量感興趣。(這個參數受版本影響), Linux執行緒一般不支持進程間共享信號量,pshared傳遞一個非零將會使函式返回ENOSYS錯誤。
(2)這兩個函式控制著信號量的值,它們的定義如下所示:
#include <semaphore.h>
int sem_wait(sem_t * sem);
int sem_post(sem_t * sem);
這兩個函式都要用一個由sem_init調用初始化的信號量對象的指針做參數。
sem_post函式的作用是給信號量的值加上一個“1”,它是一個“原子操作"即同時對同一個信號量做加“1”操作的兩個執行緒是不會衝突的;而同時對同一個檔案進行讀、加和寫操作的兩個程式就有可能會引起衝突。信號量的值永遠會正確地加一個“2”--因為有兩個執行緒試圖改變它。
sem_wait函式也是一個原子操作,它的作用是從信號量的值減去一個“1”,但它永遠會先等待該信號量為一個非零值才開始做減法。也就是說,如果你對一個值為2的信號量調用sem_wait(),執行緒將會繼續執行,信號量的值將減到1。如果對一個值為0的信號量調用sem_wait(),這個函式就會地等待直到有其它執行緒增加了這個值使它不再是0為止。如果有兩個執行緒都在sem_wait()中等待同一個信號量變成非零值,那么當它被第三個執行緒增加一個“1”時,等待執行緒中只有一個能夠對信號量做減法並繼續執行,另一個還將處於等待狀態。

相關詞條

熱門詞條

聯絡我們