名前付き共有メモリの作成

データを共有するために、複数のプロセスで、システム ページング ファイルに格納されているメモリ マップファイルを使用できます。

最初のプロセス

最初のプロセスでは、 createFileMapping 関数を呼び出し、 INVALID_HANDLE_VALUE オブジェクトの名前を指定して、ファイル マッピング オブジェクトを作成します。 PAGE_READWRITE フラグを使用すると、プロセスには、作成されたすべてのファイル ビューを介してメモリに対する読み取り/書き込みアクセス許可が付与されます。

その後、プロセスは 、CreateFileMappingMapViewOfFile の呼び出しで返すファイル マッピング オブジェクト ハンドルを使用して、プロセス アドレス空間にファイルのビューを作成します。 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;
}

2 番目のプロセス

2 番目のプロセスは、最初のプロセスと同じ名前をマッピング オブジェクトに指定して 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;
}

ファイルとメモリの共有