Schreiben in ein Mailslot

Das Schreiben in ein Maillot ähnelt dem Schreiben in eine Standarddatenträgerdatei. Der folgende Code verwendet die Funktionen CreateFile, WriteFile und CloseHandle , um eine kurze Nachricht in einem Maillot zu platzieren. Die Nachricht wird an den maillot-Server mit dem Namen "sample_mailslot" auf dem lokalen Computer gesendet. Der Code wird unter der Annahme ausgeführt, dass der maillot-Server bereits erstellt wurde.

#include <windows.h>
#include <stdio.h>

LPCTSTR SlotName = TEXT("\\\\.\\mailslot\\sample_mailslot");

BOOL WriteSlot(HANDLE hSlot, LPCTSTR lpszMessage)
{
   BOOL fResult; 
   DWORD cbWritten; 
 
   fResult = WriteFile(hSlot, 
     lpszMessage, 
     (DWORD) (lstrlen(lpszMessage)+1)*sizeof(TCHAR),  
     &cbWritten, 
     (LPOVERLAPPED) NULL); 
 
   if (!fResult) 
   { 
      printf("WriteFile failed with %d.\n", GetLastError()); 
      return FALSE; 
   } 
 
   printf("Slot written to successfully.\n"); 

   return TRUE;
}

int main()
{ 
   HANDLE hFile; 

   hFile = CreateFile(SlotName, 
     GENERIC_WRITE, 
     FILE_SHARE_READ,
     (LPSECURITY_ATTRIBUTES) NULL, 
     OPEN_EXISTING, 
     FILE_ATTRIBUTE_NORMAL, 
     (HANDLE) NULL); 
 
   if (hFile == INVALID_HANDLE_VALUE) 
   { 
      printf("CreateFile failed with %d.\n", GetLastError()); 
      return FALSE; 
   } 
 
   WriteSlot(hFile, TEXT("Message one for mailslot."));
   WriteSlot(hFile, TEXT("Message two for mailslot."));

   Sleep(5000);

   WriteSlot(hFile, TEXT("Message three for mailslot."));
 
   CloseHandle(hFile); 
 
   return TRUE;
}

Im Folgenden sehen Sie die Ausgabe, die angezeigt wird, wenn dieses Beispiel mit dem maillot-Server ausgeführt wird, der unter Lesen aus einem Mailslot angezeigt wird.

Slot written to successfully.
Slot written to successfully.
Slot written to successfully.