進程通常被定義爲一個正在運行的程序的實例,它由兩個部分組成:
一個是操作系統用來管理進程的內核對象。內核對象也是系統用來存放關於進程的統計信息的地方
另一個是地址空間,它包含所有的可執行模塊或DLL模塊的代碼和數據。它還包含動態分配的空間。如線程堆棧和堆分配空間。每個進程被賦予它自己的虛擬地址空間,當進程中的一個線程正在運行時,該線程可以訪問只屬於它的進程的內存。屬於其它進程的內存則是隱藏的,並不能被正在運行的線程訪問。
爲了能在兩個進程之間進行通訊,我們可以通過下面的方法來實現:
2。使用共享內存方式(Shared Memory)
a.設定一塊共享內存區域
HANDLE CreateFileMapping(HANDLE,LPSECURITY_ATTRIBUTES, DWORD, DWORD, DWORD, LPCSTR)
產生一個file-mapping核心對象
LPVOID MapViewOfFile(
HANDLE hFileMappingObject,
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()
這個創建內存共享我覺得是最簡單的方法:
代碼實現
在一個進程中創建共享文件
HANDLE lhShareMemory = CreateFileMapping(INVALID_HANDLE_VALUE,NULL,PAGE_READWRITE,0,1024,"penghao");
if (lhShareMemory !=NULL)
{
//AfxMessageBox("共享數據打開成功!");
}
char * strBuffer;
strBuffer = (char * ) MapViewOfFile(lhShareMemory,FILE_MAP_WRITE,0,0,1024);//獲取文件地址
strcpy(strBuffer,"update"); //寫入數據到文件中
在另一個進程中打開共享文件並訪問數據
ShellExecute(NULL,"open","processMfc.exe",0,0,SW_SHOW); //加載創建共享文件的進程
HANDLE handleFile;
handleFile= OpenFileMapping(FILE_MAP_ALL_ACCESS,false,"penghao"); //打開共享文件
if (handleFile!=NULL)
{
AfxMessageBox("共享數據打開成功");
}
char * str = NULL;
str=(char *) MapViewOfFile(handleFile,FILE_MAP_ALL_ACCESS,0,0,1024);//獲取共享文件地址,並獲取數據
if (StrCmp(str,"update")==0)
{
AfxMessageBox(str);
}
UnmapViewOfFile(str);
CloseHandle(handleFile);
return TRUE; // return TRUE unless you set the focus to a control
}