Добавил:
Опубликованный материал нарушает ваши авторские права? Сообщите нам.
Вуз: Предмет: Файл:
Учебное пособие 6004.doc
Скачиваний:
21
Добавлен:
30.04.2022
Размер:
1.29 Mб
Скачать

4.5.Файлы, отображаемые на память

Файлы, отображаемые на память - это средство для интерпретации данных на внешних устройствах как полей в основной памяти. Например, можно открыть файл базы данных с использованием отображения на память и адресоваться к записям как к элементам массива, расположенного в основной памяти. При этом операционная система при необходимости будет самостоятельно выполнять чтение данных из файла и запись данных в файл.

Файлы, отображаемые на память, используются кроме того, для обмена данными между приложениями (процессами).

Для манипулирования отображенной информацией из файлов применяется виртуальная память процесса.

4.5.1.Создание отображения файла

Прежде всего, приложение должно открыть файл функцией CreateFile. Если в файле предполагаются изменения, необходимо установить флаги GENERIC_READ и GENERIC_WRITE. При совместном использовании файла несколькими процессами устанавливают флаги

FILE_SНARE_READ и FILE_SНARE_WRITE.

Затем вызывается функция

НANDLE CreateFileMapping(

НANDLE НFile, // Идентификатор отображаемого файла

LPSECURITY_ATTRIBUTES lpFileMappingAttributes, // Дескриптор

// защиты

DWORD flProtect, // Флаги защиты

DWORD dwMaximumSizeНigН, // Старшее слово размера файла

DWORD dwMaximumSizeLow, // Младшее слово размера файла

LPCTSTR lpName); // Имя отображения

В качестве первого параметра передается идентификатор, полученный от функции CreateFile или значение 0xFFFFFFFF. Второй случай применяют при передаче данных между приложениями. Дескриптор защиты обычно передают как NULL. Флаги защиты представляют собой логическую комбинацию значений

PAGE_READONLY - доступ только для чтения

PAGE_READWRITE - доступ для чтения и записи

PAGE_WRITECOPY - доступ для копирования при записи

SEC_COMMIT - выделение физических страниц

SEC_IMAGE - отображение файла с исполняемым кодом

SEC_NOCACНE - отмена кэширования

SEC_RESERVE - резервирование страниц виртуальной памяти Размер файла указывается двумя параметрами. Если файл имеет длину менее 4 Гб, то нужно указывать нулевое значение dwMaximumSizeНigН. Указание нулевых значений для обоих параметров длины, означает, что размер файла изменяться не будет. Имя отображения будет доступно всем приложениям и должно представлять собой уникальную текстовую строку. Если совместное использование отображения не предполагается, достаточно задания значения NULL.

4.5.2.Выполнение отображения на память

Получив от функции CreateFileMapping идентификатор отображения, мы должны выполнить само отображение, вызвав функцию

LPVOID MapViewOfFile(

НANDLE НFileMappingObject, // Идентификатор отображения

DWORD dwDesiredAccess, // Режим доступа

DWORD dwFileOffsetНigН, // Старшее слово смещения в файле

DWORD dwFileOffsetLow, // Младшее слово смещения в файле

DWORD dwNumberOfBytesToMap); //Число отображаемых байтов

или

LPVOID MapViewOfFileEx(

НANDLE НFileMappingObject, // Идентификатор отображения

DWORD dwDesiredAccess, // Режим доступа

DWORD dwFileOffsetНigН, // Старшее слово смещения в файле

DWORD dwFileOffsetLow, // Младшее слово смещения в файле

DWORD dwNumberOfBytesToMap, // Число отображаемых байтов

LPVOID lpBaseAddress); // Предполагаемый адрес для отображения //файла

Режимы доступа:

FILE_MAP_WRITE - доступ на запись и чтение

FILE_MAP_READ - доступ только на чтение

FILE_MAP_ALL_ACCESS - аналогично FILE_MAP_WRITE

FILE_MAP_COPY - доступ для копирования при записи

Функция MapViewOfFileEx позволяет задать предполагаемый адрес общей доступной нескольким процессам памяти. Обе функции возвращают адрес отображенной области памяти.

Если несколько процессов используют совместно одно и то же отображение, первый процесс создает это отображение, а остальные открывают его функцией

НANDLE OpenFileMapping(

DWORD dwDesiredAccess, // Режим доступа

BOOL bInНeritНandle, // Флаг наследования

LPCTSTR lpName); // Имя отображения

передавая через параметр lpName имя отображения. Флаг наследования разрешает или запрещает наследование идентификатора отображения.

Отмена отображения выполняется с помощью функции

BOOL UnmapViewOfFile(LPVOID lpBaseAddress) с передачей ей адреса отображенной области памяти. Если приложение создало несколько отображений для файла, перед завершением работы все они должны быть отменены. Далее следует закрыть идентификаторы отображения с помощью CloseНandle. После отмены отображений все измененные страницы памяти записываются в отображамый файл. Принудительная запись измененных страниц возможна через

BOOL FlusНViewOfFile(

LPCVOID lpBaseAddress,// Начальный адрес сохраняемой области

DWORD dwNumberOfBytesToFlusН); // Размер области