程序間通訊方式分類

2021-09-26 20:41:54 字數 947 閱讀 3554

程序間通訊主要包括管道(管道包括三種)、系統ipc(包括訊息佇列,訊號,共享記憶體)、 套接字(socket)

管道:簡單

訊號:開銷小

mmap對映:非血緣關係程序間

socket(本地套接字):穩定

1、普通管道

普通管道pipe: 通常有兩種限制,一是單工,只能單向傳輸;二是只能在父子或者兄弟程序間使用.

2、流管道

流管道s_pipe: 去除了第一種限制,為半雙工,可以雙向傳輸.

3、命名管道

命名管道:name_pipe, 去除了第二種限制,可以在許多並不相關的程序之間進行通訊.

4、訊息佇列通訊

訊息佇列( message queue ) : 訊息佇列是由訊息的鍊錶,存放在核心中並由訊息佇列識別符號標識。訊息佇列克服了訊號傳遞資訊少、管道只能承載無格式位元組流以及緩衝區大小受限等缺點。

5、訊號量通訊

訊號量( semophore ) : 訊號量是乙個計數器,可以用來控制多個程序對共享資源的訪問。它常作為一種鎖機制,防止某程序正在訪問共享資源時,其他程序也訪問該資源。因此,主要作為程序間以及同一程序內不同執行緒之間的同步手段。

6、共享記憶體通訊

共享記憶體( shared memory ) :共享記憶體就是對映一段能被其他程序所訪問的記憶體,這段共享記憶體由乙個程序建立,但多個程序都可以訪問。共享記憶體是最快的 ipc 方式,它是針對其他程序間通訊方式執行效率低而專門設計的。它往往與其他通訊機制,如訊號量 配合使用,來實現程序間的同步和通訊。

7、套接字通訊

套接字( socket ) : 套介面也是一種程序間通訊機制,與其他通訊機制不同的是,它可用於不同機器間的程序通訊。

Android 程序間通訊方式彙總及分類

程序間通訊方式 aidl 功能強大,支援程序間一對多的實時併發通訊,並可實現rpc 遠端過程呼叫 messenger 支援一對多的序列實時通訊,aidl的簡化版本。bundle 四大元件的程序通訊方式,只能傳輸bundle支援的資料型別。contentprovider 強大的資料來源訪問支援,主要支...

程序間通訊方式

謝謝作者 用於程序間通訊 ipc 的四種不同技術 共享記憶體,臨界區,管道,訊息 1.訊息傳遞 管道,fifo,posix和system v訊息佇列 2.同步 互斥鎖,條件變數,讀寫鎖,檔案和記錄鎖,posix和system v訊號燈 3.共享記憶體區 匿名共享記憶體區,有名posix共享記憶體區,...

程序間通訊方式

遇到一考題,讓寫出程序間的通訊方式,突然給忘了,只想起管道和共享記憶體以及套接字。現在總結一下程序間的通訊方式以及他們之間的區別 1 管道 pipe 管道是一種半雙工的通訊方式,資料只能單向流動,而且只能在具有親緣關係的程序間使用。程序的親緣關係通常是指父子程序關係。2 有名管道 named pip...