Создание именованной общей памяти
Для совместного использования данных несколько процессов могут использовать файлы, сопоставленные с памятью, которые хранит системный файл подкачки.
Первый процесс
Первый процесс создает объект сопоставления файлов путем вызова функции CreateFileMapping с INVALID_HANDLE_VALUE и именем объекта . С помощью флага PAGE_READWRITE процесс имеет разрешение на чтение и запись в памяти через все созданные представления файлов.
Затем процесс использует дескриптор объекта сопоставления файлов, возвращаемый CreateFileMapping в вызове MapViewOfFile , чтобы создать представление файла в адресном пространстве процесса. Функция MapViewOfFile возвращает указатель на представление файла , pBuf
. Затем процесс использует функцию CopyMemory для записи строки в представление, к которому могут обращаться другие процессы.
Префикс имен объектов сопоставления файлов "Global\" позволяет процессам взаимодействовать друг с другом, даже если они находятся в разных сеансах сервера терминалов. Для этого требуется, чтобы первый процесс был иметь привилегию SeCreateGlobalPrivilege .
Если процессу больше не нужен доступ к объекту сопоставления файлов, он должен вызвать функцию CloseHandle . Когда все дескрипторы закрыты, система может освободить раздел файла подкачки, который использует объект .
#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;
}
Второй процесс
Второй процесс может получить доступ к строке, записанной в общую память первым процессом, вызвав функцию OpenFileMapping , указав то же имя объекта сопоставления, что и первый процесс. Затем он может использовать функцию MapViewOfFile для получения указателя на представление файла , pBuf
. Процесс может отобразить эту строку так же, как и любую другую строку. В этом примере отображаемое окно сообщения содержит сообщение "Сообщение от первого процесса", записанное первым процессом.
#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;
}
Связанные темы
Обратная связь
https://aka.ms/ContentUserFeedback.
Ожидается в ближайшее время: в течение 2024 года мы постепенно откажемся от GitHub Issues как механизма обратной связи для контента и заменим его новой системой обратной связи. Дополнительные сведения см. в разделеОтправить и просмотреть отзыв по