程序間通訊的方法

2022-02-12 10:24:08 字數 1897 閱讀 7737

原文出處:   程序通常被定義為乙個正在執行的程式的例項,它由兩個部分組成:

乙個是作業系統用來管理程序的核心物件。核心物件也是系統用來存放關於程序的統計資訊的地方

另乙個是位址空間,它包含所有的可執行模組或dll模組的**和資料。它還包含動態分配的空間。如執行緒堆疊和堆分配空間。每個程序被賦予它自己的虛擬位址空間,當程序中的乙個執行緒正在執行時,該執行緒可以訪問只屬於它的程序的記憶體。屬於其它程序的記憶體則是隱藏的,並不能被正在執行的執行緒訪問。

為了能在兩個程序之間進行通訊,由以下幾種方法可供參考:

0。剪貼簿clipboard: 在16位時代常使用的方式,cwnd中提供支援

1。視窗訊息 標準的windows訊息以及專用的wm_copydata訊息 sendmessage()接收端必須有乙個視窗

2。使用共享記憶體方式(shared memory)

a.設定一塊共享記憶體區域

lpvoid mapviewoffile(

dword dwdesiredacess,

dword dwfileoffsethigh,

dword dwfileoffsetlow,

dword dwnumberofbytestomap

);得到共享記憶體的指標

b.找出共享記憶體

決定這塊記憶體要以點對點(peer to peer)的形式呈現

每個程序都必須有相同的能力,產生共享記憶體並將它初始化。每個程序

錯誤**是error_already_exists,那麼程序就可以假設這一共享記憶體區 域已經被別的程序開啟並初始化了,否則該程序就可以合理的認為自己 排在第 一位,並接下來將共享記憶體初始化。

還是要使用client/server架構中

只有server程序才應該產生並初始化共享記憶體。所有的程序都應該使用

bool binherithandle,

lpctstr lpname);

再呼叫mapviewoffile(),取得共享記憶體的指標

c.同步處理(mutex)

d.清理(cleaning up) bool unmapviewoffile(lpcvoid lpbaseaddress);

closehandle()

3。動態資料交換(dde)通過維護全域性分配記憶體使的應用程式間傳遞成為可能

其方式是再一塊全域性記憶體中手工放置大量的資料,然後使用視窗訊息傳遞記憶體 指標.這是16位win時代使用的方式,因為在win32下已經沒有全域性和區域性記憶體 了,現在的記憶體只有一種就是虛存。

4。訊息管道(message pipe)

用於設定應用程式間的一條永久通訊通道,通過該通道可以象自己的應用程式

訪問乙個平面檔案一樣讀寫資料。

匿名管道(anonymous pipes)

單向流動,並且只能夠在同一電腦上的各個程序之間流動。

命名管道(named pipes)

雙向,跨網路,任何程序都可以輕易的抓住,放進管道的資料有固定的格 式,而使用readfile()只能讀取該大小的倍數。

可以被使用於i/o completion ports

5 郵件槽(mailslots)

廣播式通訊,在32系統中提供的新方法,可以在不同主機間交換資料,在 win9x下只支援郵件槽客戶

6。windows套接字(windows socket)

它具備訊息管道所有的功能,但遵守一套通訊標準使的不同作業系統之上的應 用程式之間可以互相通訊。

8。rpc:遠端過程呼叫,很少使用,因其與unix的rpc不相容。

9。序列/並行通訊(serial/parallel communication)

它允許應用程式通過序列或並行埠與其他的應用程式通訊

通過com系統的**存根方式進行程序間資料交換,但只能夠表現在對介面 函式的呼叫時傳送資料,通過dcom可以在不同主機間傳送資料。

程序間通訊方法

1 管道 pipe 管道可用於具有親緣關係程序間的通訊,允許乙個程序和另乙個與它有共同祖先的程序之間進行通訊。2 命名管道 named pipe 命名管道克服了管道沒有名字的限制,因此,除具有管道所具有的功能外,它還允許無親緣關 系 程序間的通訊。命名管道在檔案系統中有對應的檔名。命名管道通過命令m...

程序間通訊的方法

程序間通訊的方法 1.管道 pipe 管道是一種半雙工的通訊方式,資料只能單向流動,而且只能在具有親緣關係的程序間使用。程序的親緣關係通常是指父子程序關係。2.有名管道 named pipe 有名管道也是半雙工的通訊方式,但是它允許無親緣關係程序間的通訊。3.訊號量 semophore 訊號量是乙個...

程序間通訊 IPC 方法

程序間通訊 ipc 方法主要有以下幾種 管道 fifo 共享記憶體 訊息佇列 訊號量 1.管道中還有命名管道和非命名管道 即匿名管道 之分,非命名管道 即匿名管道 只能用於父子程序通訊,命名管道可用於非父子程序,命名管道就是fifo,管道是先進先出的通訊方式 2.訊息佇列是用於兩個程序之間的通訊,首...