程序間的通訊方式

2021-10-09 12:52:15 字數 1729 閱讀 8491

管道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共享記憶體區,...