Udostępnij za pośrednictwem


Korzystanie ze strumieni

W przykładzie w tym temacie pokazano, jak używać podstawowych strumieni systemu plików NTFS.

W tym przykładzie tworzony jest plik o nazwie "TestFile" o rozmiarze 16 bajtów. Jednak plik ma również dodatkowy typ strumienia ::$DATA o nazwie "Stream", który dodaje dodatkowe 23 bajty, które nie są zgłaszane przez system operacyjny. W związku z tym podczas wyświetlania właściwości rozmiaru pliku zobaczysz tylko rozmiar domyślnego strumienia ::$DATA dla pliku.

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

void main( )
 {
  HANDLE hFile, hStream;
  DWORD dwRet;

  hFile = CreateFile( TEXT("TestFile"), // Filename
                      GENERIC_WRITE,    // Desired access
                      FILE_SHARE_WRITE, // Share flags
                      NULL,             // Security Attributes
                      OPEN_ALWAYS,      // Creation Disposition
                      0,                // Flags and Attributes
                      NULL );           // OVERLAPPED pointer
  if( hFile == INVALID_HANDLE_VALUE )
   {
    printf( "Cannot open TestFile\n" );
    return;
   }
  else
   {
    WriteFile( hFile,              // Handle
               "This is TestFile", // Data to be written
               16,                 // Size of data, in bytes
               &dwRet,             // Number of bytes written
               NULL );             // OVERLAPPED pointer
    CloseHandle( hFile );
    hFile = INVALID_HANDLE_VALUE;
   }

  hStream = CreateFile( TEXT("TestFile:Stream"), // Filename
                        GENERIC_WRITE,           // Desired access
                        FILE_SHARE_WRITE,        // Share flags
                        NULL,                    // Security Attributes
                        OPEN_ALWAYS,             // Creation Disposition
                        0,                       // Flags and Attributes
                        NULL );                  // OVERLAPPED pointer
  if( hStream == INVALID_HANDLE_VALUE )
    printf( "Cannot open TestFile:Stream\n" );
  else
   {
    WriteFile( hStream,                   // Handle
               "This is TestFile:Stream", // Data to be written
               23,                        // Size of data
               &dwRet,                    // Number of bytes written
               NULL);                     // OVERLAPPED pointer
    CloseHandle( hStream );
    hStream = INVALID_HANDLE_VALUE;
   }
}

Jeśli wpiszesz Wpisz plik TestFile w wierszu polecenia, zostaną wyświetlone następujące dane wyjściowe:

This is TestFile

Jeśli jednak wpiszesz wyrazy Type TestFile:Stream, spowoduje to wygenerowanie następującego błędu:

"Nazwa pliku, nazwa katalogu lub składnia etykiety woluminu jest nieprawidłowa".

Aby wyświetlić zawartość pliku TestFile:stream, użyj jednego z następujących poleceń:

więcej < TestFile:Stream

więcej < TestFile:Stream:$DATA

Wyświetlany tekst jest następujący:

This is TestFile:Stream

strumienie plików