程式間的通訊實現(IPC)的11種方法 (轉)
程式通常被定義為一個正在執行的的例項,它由兩個部分組成:
一個是操作用來管理程式的核心。核心物件也是系統用來存放關於程式的統計資訊的地方
另一個是地址空間,它包含所有的可模組或DLL模組的程式碼和資料。它還包含動態分配的空間。如執行緒堆疊和堆分配空間。每個程式被賦予它自己的虛擬地址空間,當程式中的一個執行緒正在執行時,該執行緒可以訪問只屬於它的程式的。屬於其它程式的記憶體則是隱藏的,並不能被正在執行的執行緒訪問。
為了能在兩個程式之間進行通訊,由以下幾種方法可供參考:
0。剪貼簿Clipboard: 在16位時代常使用的方式,CWnd中提供支援
1。視窗訊息 標準的訊息以及專用的WM_COPYDATA訊息 SENDMESSAGE()接收端必須有一個視窗
2。使用共享記憶體方式(Shared Memory)
a.設定一塊共享記憶體區域
HANDLE CreateFileMap(HANDLE,LPSECURITY_ATTRIBUTES, D, DWORD, DWORD, LPCSTR)
產生一個file-mapping核心物件
LPVOID MapViewOfFile(
HANDLE hFileMapping,
DWORD dwDesiredAcess,
DWORD dwFileOffsetHigh,
DWORD dwFileOffsetLow,
DWORD dwNumberOfBytesToMap
);
得到共享記憶體的指標
b.找出共享記憶體
決定這塊記憶體要以點對點(peer to peer)的形式呈現
每個程式都必須有相同的能力,產生共享記憶體並將它初始化。每個程式
都應該CreateFileMapping(),然後呼叫GetLastError().如果傳回的
錯誤程式碼是ERROR_ALREADY_EXISTS,那麼程式就可以假設這一共享記憶體區 域已經被別的程式開啟並初始化了,否則該程式就可以合理的認為自己 排在第 一位,並接下來將共享記憶體初始化。
還是要使用client/server架構中
只有server程式才應該產生並初始化共享記憶體。所有的程式都應該使用
HANDLE OpenFileMapping(DWORD dwDesiredAccess,
BOOL bInheritHandle,
LPCTSTR lpName);
再呼叫MapViewOfFile(),取得共享記憶體的指標
c.同步處理(Mutex)
d.清理(Cleaning up) BOOL UnmapViewOfFile(LPCVOID lpBaseAddress);
CloseHandle()
3。動態資料(DDE)透過維護全域性分配記憶體使的應用程式間傳遞成為可能
其方式是再一塊全域性記憶體中手工放置大量的資料,然後使用視窗訊息傳遞記憶體 指標.這是16位WIN時代使用的方式,因為在下已經沒有全域性和區域性記憶體 了,現在的記憶體只有一種就是虛存。
4。訊息管道(Message Pipe)
用於設定應用程式間的一條永久通訊通道,透過該通道可以象自己的應用程式
訪問一個平面一樣讀寫資料。
匿名管道(Anonymous Pipes)
單向流動,並且只能夠在同一上的各個程式之間流動。
命名管道(Named Pipes)
雙向,跨,任何程式都可以輕易的抓住,放進管道的資料有固定的格 式,而使用ReadFile()只能讀取該大小的倍數。
可以被使用於I/O Completion Ports
5 槽(slots)
廣播式通訊,在32系統中提供的新方法,可以在不同主機間交換資料,在 下只支援郵件槽客戶
6。Windows套接字(Windows Socket)
它具備訊息管道所有的功能,但遵守一套通訊標準使的不同之上的應 用程式之間可以互相通訊。
7。Inte通訊 它讓應用程式從Internet地址上載或檔案
8。RPC:過程呼叫,很少使用,因其與的RPC不相容。
9。/並行通訊(Serial/Parallel Communication)
它允許應用程式透過序列或並行埠與其他的應用程式通訊
10。COM/D
透過COM系統的存根方式進行程式間資料交換,但只能夠表現在對介面 的呼叫時傳送資料,透過DCOM可以在不同主機間傳送資料。
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/10752043/viewspace-993035/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- 程式間通訊(IPC) 的限制
- 程式間通訊 --IPC
- 微服務的程式間通訊(IPC)微服務
- IPC-程式間通訊
- C++程式間通訊的十一種方法C++
- 程式間的八種通訊方式----共享記憶體是最快的 IPC 方式記憶體
- Android程式間通訊–訊息機制及IPC機制實現薦Android
- linux程式間通訊(IPC)小結Linux
- 【IPC程式間通訊之二】管道PipeC程式
- 實現不同程式之間的通訊
- 程式間通訊的另類實現
- 實現多個標籤頁之間通訊的幾種方法
- 【IPC程式間通訊之一】郵槽MailSlotC程式AI
- 程式間通訊——XSI IPC之訊息佇列佇列
- 程式間的幾種通訊方式
- 幾種程式間的通訊方式
- 程式間的8種通訊方式
- 使用AIDL實現程式間的通訊AI
- 用NSConnection實現不同程式間的通訊
- Android IPC程式間通訊之AIDL和Messenger的使用AndroidC程式AIMessenger
- 程式間的五種通訊方式介紹
- 通過 App Groups 實現程式間通訊APP
- 在 OpenResty 裡實現程式間通訊REST
- 程式間的通訊
- Linux 程式間通訊的六種機制Linux
- 【IPC程式間通訊之四】資料複製訊息WM_COPYDATAC程式
- 什麼是程式間通訊?Linux程式間通訊有幾種方式?Linux
- 程式間通訊是什麼?Linux程式間通訊有幾種方式?Linux
- Java中利用管道實現執行緒間的通訊(轉)Java執行緒
- liunx使用者空間和核心空間之間的通訊實現(在PPC下的實現)(轉)
- Java通過wait()和notifyAll()方法實現執行緒間的通訊JavaAI執行緒
- linux環境程式設計(3): 使用POSIX IPC完成程式間通訊Linux程式設計
- 程式間的五種通訊方式介紹-詳解
- Linux程式間通訊的6種不同方式Linux
- 實驗八 程式間通訊
- IPC Kit基礎入門:理解HarmonyOS的程序間通訊架構架構
- T面試題:程式間的通訊方式有哪幾種?面試題
- C#程式間通訊的各種途徑及解析C#