進(jìn)程通常被定義為一個(gè)正在運(yùn)行的程序的實(shí)例,它由兩個(gè)部分組成:
一個(gè)是操作系統(tǒng)用來(lái)管理進(jìn)程的內(nèi)核對(duì)象。內(nèi)核對(duì)象也是系統(tǒng)用來(lái)存放關(guān)于進(jìn)程的統(tǒng)計(jì)信息的地方;另一個(gè)是地址空間,它包含所有的可執(zhí)行模塊或DLL模塊的代碼和數(shù)據(jù)。它還包含動(dòng)態(tài)分配的空間。如線程堆棧和堆分配空間。每個(gè)進(jìn)程被賦予它自己的虛擬地址空間,當(dāng)進(jìn)程中的一個(gè)線程正在運(yùn)行時(shí),該線程可以訪問只屬于它的進(jìn)程的內(nèi)存。屬于其它進(jìn)程的內(nèi)存則是隱藏的,并不能被正在運(yùn)行的線程訪問。為了能在兩個(gè)進(jìn)程之間進(jìn)行通訊,由以下幾種方法可供參考:
1、剪貼板Clipboard: 在16位時(shí)代常使用的方式,CWnd中提供支持。
2、窗口消息 標(biāo)準(zhǔn)的Windows消息以及專用的WM_COPYDATA消息 SENDMESSAGE()接收端必須有一個(gè)窗口。
3、使用共享內(nèi)存方式(Shared Memory)a.設(shè)定一塊共享內(nèi)存區(qū)域HANDLECreateFileMapping(HANDLE,LPSECURITY_ATTRIBUTES, DWORD, DWORD, DWORD,LPCSTR) ,產(chǎn)生一個(gè)file-mapping核心對(duì)象LPVOID MapViewOfFile(HANDLE hFileMappingObject,DWORD dwDesiredAcess,DWORD dwFileOffsetHigh,DWORD dwFileOffsetLow,DWORD dwNumberOfBytesToMap);得到共享內(nèi)存的指針。b.找出共享內(nèi)存,決定這塊內(nèi)存要以點(diǎn)對(duì)點(diǎn)(peer to peer)的形式呈現(xiàn)每個(gè)進(jìn)程都必須有相同的能力,產(chǎn)生共享內(nèi)存并將它初始化。每個(gè)進(jìn)程都應(yīng)該調(diào)用CreateFileMapping(),然后調(diào)用GetLastError().如果傳回的錯(cuò)誤代碼是ERROR_ALREADY_EXISTS,那么進(jìn)程就可以假設(shè)這一共享內(nèi)存區(qū)域已經(jīng)被別的進(jìn)程打開并初始化了,否則該進(jìn)程就可以合理的認(rèn)為自己 排在第 一位,并接下來(lái)將共享內(nèi)存初始化。還是要使用client/server架構(gòu)中只有server進(jìn)程才應(yīng)該產(chǎn)生并初始化共享內(nèi)存。所有的進(jìn)程都應(yīng)該使用HANDLE OpenFileMapping(DWORD dwDesiredAccess,BOOL bInheritHandle,LPCTSTR lpName);再調(diào)用MapViewOfFile(),取得共享內(nèi)存的指針。c.同步處理(Mutex)。d.清理(Cleaningup) BOOL UnmapViewOfFile(LPCVOID lpBaseAddress);CloseHandle()。
4、動(dòng)態(tài)數(shù)據(jù)交換(DDE)通過維護(hù)全局分配內(nèi)存使的應(yīng)用程序間傳遞成為可能,其方式是再一塊全局內(nèi)存中手工放置大量的數(shù)據(jù),然后使用窗口消息傳遞內(nèi)存 指針.這是16位WIN時(shí)代使用的方式,因?yàn)樵赪IN32下已經(jīng)沒有全局和局部?jī)?nèi)存 了,現(xiàn)在的內(nèi)存只有一種就是虛存。
5、消息管道(Message Pipe)用于設(shè)置應(yīng)用程序間的一條永久通訊通道,通過該通道可以象自己的應(yīng)用程序訪問一個(gè)平面文件一樣讀寫數(shù)據(jù)。匿名管道(Anonymous Pipes)單向流動(dòng),并且只能夠在同一電腦上的各個(gè)進(jìn)程之間流動(dòng)。命名管道(Named Pipes)雙向,跨網(wǎng)絡(luò),任何進(jìn)程都可以輕易的抓住,放進(jìn)管道的數(shù)據(jù)有固定的格 式,而使用ReadFile()只能讀取該大小的倍數(shù)??梢员皇褂糜贗/O Completion Ports。
6、郵件槽(Mailslots),廣播式通信,在32系統(tǒng)中提供的新方法,可以在不同主機(jī)間交換數(shù)據(jù),在 WIN9X下只支持郵件槽客戶、Windows套接字(Windows Socket)它具備消息管道所有的功能,但遵守一套通信標(biāo)準(zhǔn)使的不同操作系統(tǒng)之上的應(yīng) 用程序之間可以互相通信。
8、Internet通信它讓應(yīng)用程序從Internet地址上載或下載文件。
9、RPC:遠(yuǎn)程過程調(diào)用,很少使用,因其與UNIX的RPC不兼容。
10、串行/并行通信(Serial/Parallel Communication)它允許應(yīng)用程序通過串行或并行端口與其他的應(yīng)用程序通信
11、COM/DCOM通過COM系統(tǒng)的代理存根方式進(jìn)行進(jìn)程間數(shù)據(jù)交換,但只能夠表現(xiàn)在對(duì)接口 函數(shù)的調(diào)用時(shí)傳送數(shù)據(jù),通過DCOM可以在不同主機(jī)間傳送數(shù)據(jù)。
-
內(nèi)核
+關(guān)注
關(guān)注
3文章
1384瀏覽量
40444 -
內(nèi)存
+關(guān)注
關(guān)注
8文章
3066瀏覽量
74388 -
串行通信
+關(guān)注
關(guān)注
4文章
579瀏覽量
35611 -
數(shù)據(jù)交換
+關(guān)注
關(guān)注
0文章
104瀏覽量
17972
原文標(biāo)題:C++中進(jìn)程間相互通信的十一種方法
文章出處:【微信號(hào):C_Expert,微信公眾號(hào):C語(yǔ)言專家集中營(yíng)】歡迎添加關(guān)注!文章轉(zhuǎn)載請(qǐng)注明出處。
發(fā)布評(píng)論請(qǐng)先 登錄
相關(guān)推薦
電池電量的兩種測(cè)試方法
labview與51串口通信的兩種方式
用兩種方法解決電路設(shè)計(jì)問題
STM32操作矩陣鍵盤的兩種方法
1.3 兩種運(yùn)行 Python 程序方法
檢測(cè)電池電量的兩種方法
單片機(jī)系統(tǒng)實(shí)現(xiàn)延時(shí)的兩種方法解析
![單片機(jī)系統(tǒng)實(shí)現(xiàn)延時(shí)的<b class='flag-5'>兩種方法</b>解析](https://file.elecfans.com/web1/M00/B2/45/pIYBAF4FyXiADHT6AAGa7xHnJuw563.png)
片機(jī)實(shí)現(xiàn)延時(shí)的兩種方法
單片機(jī)實(shí)現(xiàn)延時(shí)兩種方法
![單片機(jī)實(shí)現(xiàn)延時(shí)<b class='flag-5'>兩種方法</b>](https://file.elecfans.com/web1/M00/D9/4E/pIYBAF_1ac2Ac0EEAABDkS1IP1s689.png)
STM32操作矩陣鍵盤的兩種方法——掃描和中斷
![STM32操作矩陣鍵盤的<b class='flag-5'>兩種方法</b>——掃描和中斷](https://file.elecfans.com/web1/M00/D9/4E/pIYBAF_1ac2Ac0EEAABDkS1IP1s689.png)
簡(jiǎn)述安裝打印機(jī)驅(qū)動(dòng)的兩種方法
![簡(jiǎn)述安裝打印機(jī)驅(qū)動(dòng)的<b class='flag-5'>兩種方法</b>](https://file1.elecfans.com/web2/M00/81/F8/wKgaomQrgSqAXfVkAAEmFiRWCcw273.jpg)
評(píng)論