Elnevezett megosztott memória létrehozása
Az adatok megosztásához több folyamat is használhat memórialeképezett fájlokat, amelyeket a rendszer lapozófájlként tárol.
Jegyzet
A példában szereplő kód futásidőben rendszergazdai jogosultságokat igényel.
Első folyamat
Az első folyamat úgy hozza létre a fájlleképezési objektumot, hogy meghívja a CreateFileMapping függvényt INVALID_HANDLE_VALUE és az objektum nevét. A PAGE_READWRITE jelző használatával a folyamat olvasási/írási engedéllyel rendelkezik a memóriához a létrehozott fájlnézeteken keresztül.
Ezután a folyamat a Fájlleképezési objektum leíróját használja, amelyet CreateFileMapping a MapViewOfFilehívásában ad vissza, hogy létrehozhasson egy nézetet a fájlról a folyamat címterében. A MapViewOfFile függvény egy mutatót ad vissza a fájlnézethez, pBuf
. A folyamat ezután a CopyMemory függvénnyel sztringet ír a más folyamatok által elérhető nézetbe.
A fájlleképezési objektumnevek "Global\" előtaggal való előtagolásával a folyamatok akkor is kommunikálhatnak egymással, ha különböző terminálkiszolgáló-munkamenetekben vannak. Ehhez az első folyamatnak SeCreateGlobalPrivilege jogosultsággal kell rendelkeznie.
Ha a folyamatnak már nincs szüksége a fájlleképezési objektumhoz való hozzáférésre, a CloseHandle függvényt kell meghívnia. Amikor az összes fogantyú zárva van, a rendszer felszabadíthatja az objektum által használt lapozófájl szakaszát.
#include <windows.h>
#include <stdio.h>
#include <conio.h>
#include <tchar.h>
#define BUF_SIZE 256
TCHAR szName[]=TEXT("Global\\MyFileMappingObject");
TCHAR szMsg[]=TEXT("Message from first process.");
int _tmain()
{
HANDLE hMapFile;
LPCTSTR pBuf;
hMapFile = CreateFileMapping(
INVALID_HANDLE_VALUE, // use paging file
NULL, // default security
PAGE_READWRITE, // read/write access
0, // maximum object size (high-order DWORD)
BUF_SIZE, // maximum object size (low-order DWORD)
szName); // name of mapping object
if (hMapFile == NULL)
{
_tprintf(TEXT("Could not create file mapping object (%d).\n"),
GetLastError());
return 1;
}
pBuf = (LPTSTR) MapViewOfFile(hMapFile, // handle to map object
FILE_MAP_ALL_ACCESS, // read/write permission
0,
0,
BUF_SIZE);
if (pBuf == NULL)
{
_tprintf(TEXT("Could not map view of file (%d).\n"),
GetLastError());
CloseHandle(hMapFile);
return 1;
}
CopyMemory((PVOID)pBuf, szMsg, (_tcslen(szMsg) * sizeof(TCHAR)));
_getch();
UnmapViewOfFile(pBuf);
CloseHandle(hMapFile);
return 0;
}
Második folyamat
A második folyamat a OpenFileMapping függvény meghívásával elérheti a megosztott memóriába írt sztringet, amely ugyanazt a nevet adja meg a leképezési objektumnak, mint az első folyamat. Ezután a MapViewOfFile függvénnyel lekérte a fájlnézetre mutató mutatót, pBuf
. A folyamat ugyanúgy jelenítheti meg ezt a sztringet, mint bármely más sztringet. Ebben a példában a megjelenő üzenetmező tartalmazza az "Üzenet az első folyamatból" üzenetet, amelyet az első folyamat írt.
#include <windows.h>
#include <stdio.h>
#include <conio.h>
#include <tchar.h>
#pragma comment(lib, "user32.lib")
#define BUF_SIZE 256
TCHAR szName[]=TEXT("Global\\MyFileMappingObject");
int _tmain()
{
HANDLE hMapFile;
LPCTSTR pBuf;
hMapFile = OpenFileMapping(
FILE_MAP_ALL_ACCESS, // read/write access
FALSE, // do not inherit the name
szName); // name of mapping object
if (hMapFile == NULL)
{
_tprintf(TEXT("Could not open file mapping object (%d).\n"),
GetLastError());
return 1;
}
pBuf = (LPTSTR) MapViewOfFile(hMapFile, // handle to map object
FILE_MAP_ALL_ACCESS, // read/write permission
0,
0,
BUF_SIZE);
if (pBuf == NULL)
{
_tprintf(TEXT("Could not map view of file (%d).\n"),
GetLastError());
CloseHandle(hMapFile);
return 1;
}
MessageBox(NULL, pBuf, TEXT("Process2"), MB_OK);
UnmapViewOfFile(pBuf);
CloseHandle(hMapFile);
return 0;
}