無名訊號量實現相關程序同步

2021-08-07 04:58:13 字數 874 閱讀 7614

/*

名稱:無名訊號量實現相關程序同步

說明:此處使用的是實現相關程序同步的實驗程式(改編自教材)。

有幾點需要強調下

1.兩個程序之間有不同的位址空間(即使是用fork生成的相同的程序,它們中的內容相同但是,但是位址空間是不同的)。雖然使用了posix的的sem_init宣告了乙個共享的訊號量sem ,但是當兩個程序執行不同的操作後,每個程序中的sem_id仍然是在不同的位址上。也就是說,在呼叫fork函式的父子程序之間使用無名訊號量也必須將其放入在父子程序共享的記憶體區域,這也是本實驗中mmap()函式的作用。

2.本程式實現的是單項同步,也就是利用訊號量實現前驅關係。在本實驗中,理論上將先輸出父程序中的count,然後子程序的count,然後父程序,然後再子程序….

#include 

#include

#include

#include

#include

#define countno 20

sem_t sem;

sem_t *psem = null;

int main(int argc, char *argv)

if (sem_init(psem, 1, 1) == -1)

sem_getvalue(psem,&val);

printf("this is the main function the psem value is %d\n",val);

pid = fork();

if(pid==0)

} else

}

sem_destroy(psem);

return

0;}

程序同步 訊號量機制

由dijkstra提出,目前已廣泛應用於單處理機和多處理機系統以及計算機網路中。一 整形訊號量 1.s 乙個用於表示資源數目的整型量 2.與一般整型量不同,除初始化外,僅能通過兩個標準的原子操作 wait s 和signal s 長期以來一直被稱為p v操作 3.wait操作偽碼描述 wait s ...

程序同步與訊號量

對於多個程序訪問共享資料,需要程序進行同步合作完成操作。我們可以使用訊號量來描述共享資料。struct semaphore p semaphore s v semaphore s 這樣的話當我們訪問共享資料時,我們可以先呼叫p操作,訪問結束後呼叫v操作,這樣就可以當成程序同步的目的。使用訊號量的問題...

程序同步與訊號量

二.訊號量臨界區保護 三.訊號量的 實現 訊號量是用來記錄可用資源或等待執行緒數目的一種特殊的整形變數。通過對訊號量的修改,使得各個程序得以有序推進,完成程序同步。訊號量的 定義 struct semaphore兩種基本操作 當程序申請消費資源時執行p函式。首先將資源數目value減一,然後判斷va...