管道pipe:管道是一種半雙工的通訊方式,資料只能單向流動,而且只能在具有親緣關係的程序間使用。程序的親緣關係通常是指父子程序關係。
管道是一種最基本的ipc(inter-process communication)機制,作用於有血緣關係的程序之間,完成資料傳遞。呼叫pipe系統函式即可建立乙個管道。有如下特質:
其本質是乙個偽檔案(實為核心緩衝區)
由兩個檔案描述符引用,乙個表示讀端,乙個表示寫端。
規定資料從管道的寫端流入管道,從讀端流出。
管道的原理: 管道實為核心使用環形佇列機制,借助**核心緩衝區(4k)**實現。
管道的侷限性:
資料自己讀不能自己寫。
資料一旦被讀走,便不在管道中存在,不可反覆讀取。
由於管道採用半雙工通訊方式。因此,資料只能在乙個方向上流動。
只能在有公共祖先的程序間使用管道。
常見的通訊方式有,單工通訊、半雙工通訊、全雙工通訊。
pipe:建立管道。
表頭檔案
#include
unix standard header定義函式
int
pipe
(int filedes[2]
);
函式說明
pipe()會建立管道,並將檔案描述詞由引數filedes陣列返回。
filedes[0]為管道裡的讀取端,filedes[1]則為管道的寫入端。
返回值 若成功則返回零,否則返回-1,錯誤原因存於errno中。
錯誤**
emfile:程序已用完檔案描述詞最大量。
enfile:系統已無檔案描述詞可用。
命名管道fifo:有名管道也是半雙工的通訊方式,但是它允許無親緣關係程序間的通訊。
訊息佇列messagequeue:訊息佇列是由訊息的鍊錶,存放在核心中並由訊息佇列識別符號標識。訊息佇列克服了訊號傳遞資訊少、管道只能承載無格式位元組流以及緩衝區大小受限等缺點。
共享記憶體sharedmemory:共享記憶體就是對映一段能被其他程序所訪問的記憶體,這段共享記憶體由乙個程序建立,但多個程序都可以訪問。共享記憶體是最快的 ipc 方式,它是針對其他程序間通訊方式執行效率低而專門設計的。它往往與其他通訊機制,如訊號量,配合使用,來實現程序間的同步和通訊。
訊號量semaphore:訊號量是乙個計數器,可以用來控制多個程序對共享資源的訪問。它常作為一種鎖機制,防止某程序正在訪問共享資源時,其他程序也訪問該資源。因此,主要作為程序間以及同一程序內不同執行緒之間的同步手段。
套接字socket:套解口也是一種程序間通訊機制,與其他通訊機制不同的是,它可用於不同及其間的程序通訊。
訊號 ( signal ) : 訊號是一種比較複雜的通訊方式,用於通知接收程序某個事件已經發生。
程序間的通訊方式,執行緒間的通訊方式 程序
當時做筆記的時候 忘了在 看到的了,有時間我再研究研究 管道 pipe 管道是一種半雙工的通訊方式,資料只能單向流動,而且只能在具有親緣關係的程序間使用。程序的親緣關係通常是指父子程序關係。有名管道 namedpipe 有名管道也是半雙工的通訊方式,但是它允許無親緣關係程序間的通訊。訊號量 semo...
程序間通訊的方式?執行緒間通訊的方式?
管道 命名管道 訊號量 訊息佇列 訊號及共享記憶體只適用於本地程序間通訊,套接字則可用於遠端通訊,因而一般用於網路程式設計。部分概念解釋 匿名管道是在快取中開闢的輸出和輸入檔案流的空間,只能用於父子關係的程序之間。因為父子程序的輸入和輸出檔案描述符是一致的。命名管道是一種實際存在的fifo檔案,稱作...
程序間通訊方式
謝謝作者 用於程序間通訊 ipc 的四種不同技術 共享記憶體,臨界區,管道,訊息 1.訊息傳遞 管道,fifo,posix和system v訊息佇列 2.同步 互斥鎖,條件變數,讀寫鎖,檔案和記錄鎖,posix和system v訊號燈 3.共享記憶體區 匿名共享記憶體區,有名posix共享記憶體區,...