Vytvoření pojmenované sdílené paměti
K ukládání dat může více procesů využívat soubory mapované v paměti, které jsou uloženy ve stránkovacím souboru systému.
Poznámka
Kód v tomto příkladu bude vyžadovat oprávnění správce za běhu.
První proces
První proces vytvoří objekt mapování souboru voláním funkce CreateFileMapping s INVALID_HANDLE_VALUE a názvem objektu. Pomocí příznaku PAGE_READWRITE má proces oprávnění ke čtení a zápisu do paměti prostřednictvím všech vytvořených zobrazení souborů.
Pak proces použije popisovač objektu mapování souborů, který vrátí funkce CreateFileMapping při volání funkce MapViewOfFile, aby vytvořil zobrazení souboru v adresním prostoru procesu. Funkce MapViewOfFile vrátí ukazatel na zobrazení souboru pBuf
. Proces pak použije funkci CopyMemory k zápisu řetězce do zobrazení, ke kterému mají přístup jiné procesy.
Přidáním předpony "Global\" k názvům objektů mapování souborů lze procesům vzájemně komunikovat, i když se nacházejí v různých relacích terminálového serveru. To vyžaduje, aby první proces měl oprávnění SeCreateGlobalPrivilege.
Pokud už proces nepotřebuje přístup k objektu mapování souboru, měl by volat funkci CloseHandle. Po zavření všech popisovačů může systém uvolnit tu část stránkovacího souboru, kterou objekt používá.
#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;
}
Druhý proces
Druhý proces má přístup k řetězci zapsaného do sdílené paměti prvním procesem voláním OpenFileMapping funkce určující stejný název objektu mapování jako první proces. Pak může funkci MapViewOfFile použít k získání ukazatele na zobrazení souboru, pBuf
. Proces může tento řetězec zobrazit stejně jako jakýkoli jiný řetězec. V tomto příkladu obsahuje zobrazené pole zprávy zprávu "Zpráva od prvního procesu", která byla napsána prvním procesem.
#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;
}