管道這種通訊方式有兩種限制,一是半雙工的通訊,資料只能單向流動,二是只能在具有親緣關係的程序間使用。程序的親緣關係通常是指父子程序關係。
流管道s_pipe: 去除了第一種限制,可以雙向傳輸(全雙工)
管道可用於具有親緣關係程序間的通訊,命名管道:name_pipe克服了管道沒有名字的限制,因此,除具有管道所具有的功能外,它還允許無親緣關係程序間的通訊;
訊號是一種比較複雜的通訊方式,用於通知接收程序某個事件已經發生。
主要作為程序間以及同一程序不同執行緒之間的同步手段。
訊號量是乙個計數器,可以用來控制多個程序對共享資源的訪問。它常作為一種鎖機制,防止某程序正在訪問共享資源時,其他程序也訪問該資源。因此,主要作為程序間以及同一程序內不同執行緒之間的同步手段。
訊息佇列是由訊息組成的鍊錶,存放在核心中並由訊息佇列識別符號標識。
訊息佇列是訊息的鏈結表,包括posix訊息佇列system v訊息佇列。有足夠許可權的程序可以向佇列中新增訊息,被賦予讀許可權的程序則可以讀走佇列中的訊息。訊息佇列克服了訊號承載資訊量少,管道只能承載無格式位元組流以及緩衝區大小受限等缺點。
共享記憶體就是對映一段能被其他程序所訪問的記憶體,這段共享記憶體由乙個程序建立,但多個程序都可以訪問。共享記憶體是最快的 ipc 方式,它是針對其他程序間通訊方式執行效率低而專門設計的。它往往與其他通訊機制,如訊號量,配合使用,來實現程序間的同步和通訊。
套解字也是一種程序間通訊機制,與其他通訊機制不同的是,它可用於不同機器間的程序通訊。
管道:速度慢,容量有限,只有父子程序能通訊
fifo:任何程序間都能通訊,但速度慢
訊息佇列: 容量受到系統限制,且要注意第一次讀的時候,要考慮上一次沒有讀完資料的問題,訊息佇列可以不再侷限於父子程序,而允許任意程序通過共享訊息佇列來實現程序間通訊,並由系統呼叫函式來實現訊息傳送和接收之間的同步,從而使得使用者在使用訊息緩衝進行通訊時不再需要考慮同步問題,使用方便,但是資訊的複製需要額外消耗cpu的時間,不適宜於資訊量大或操作頻繁的場合。此種方法不太常用
訊號量: 不能用來傳遞復雜訊息,只能用來同步
共享記憶體:利用記憶體緩衝區直接交換資訊,無須複製,快捷、資訊量大是其優點。共享記憶體塊提供了在任意數量的程序之間進行高效雙向通訊的機制。每個使用者都可以讀取寫入資料,但是所有程式之間必須達成並遵守一定的協議,以防止諸如在讀取資訊之前覆寫記憶體空間等競爭狀態的出現。
程序間的通訊方式,執行緒間的通訊方式 程序
當時做筆記的時候 忘了在 看到的了,有時間我再研究研究 管道 pipe 管道是一種半雙工的通訊方式,資料只能單向流動,而且只能在具有親緣關係的程序間使用。程序的親緣關係通常是指父子程序關係。有名管道 namedpipe 有名管道也是半雙工的通訊方式,但是它允許無親緣關係程序間的通訊。訊號量 semo...
程序間通訊的方式?執行緒間通訊的方式?
管道 命名管道 訊號量 訊息佇列 訊號及共享記憶體只適用於本地程序間通訊,套接字則可用於遠端通訊,因而一般用於網路程式設計。部分概念解釋 匿名管道是在快取中開闢的輸出和輸入檔案流的空間,只能用於父子關係的程序之間。因為父子程序的輸入和輸出檔案描述符是一致的。命名管道是一種實際存在的fifo檔案,稱作...
程序間通訊方式
謝謝作者 用於程序間通訊 ipc 的四種不同技術 共享記憶體,臨界區,管道,訊息 1.訊息傳遞 管道,fifo,posix和system v訊息佇列 2.同步 互斥鎖,條件變數,讀寫鎖,檔案和記錄鎖,posix和system v訊號燈 3.共享記憶體區 匿名共享記憶體區,有名posix共享記憶體區,...