內存文件映射應用舉例

下面這些函數被應用於文件內存映射中:

1) CreateFileMapping
2) FlushViewOfFile
3) MapViewOfFile
4) MapViewOfFileEx
5) MapViewOfFileVlm
6) OpenFileMapping
7) UnmapViewOfFile  
8) UnmapViewOfFileVlm

函數詳細說明:『見本頁末』

 

一、CreateFileMapping 爲指定文件創建一個有名或無名的文件映象;
HANDLE CreateFileMapping(
HANDLE hFile,              // 映射文件的句柄
LPSECURITY_ATTRIBUTES lpFileMappingAttributes,
                             // 安全描述符指針
DWORD flProtect,           // 對映射對象的保護
DWORD dwMaximumSizeHigh,   // 對象最大長度的高32位
DWORD dwMaximumSizeLow,    // 對象最大長度的低32位
LPCTSTR lpName             // 文件內存映射對象的名字
);

注意:
hFile:映射文件的句柄,文件的打開模式必須與flProtect參數指定的相一致;如果這個參數值爲0xFFFFFFFF,那 麼必須在dwMaximumSizeHigh和dwMaximumSizeLow參數中指定映射對象的大小。並且將在操作系統虛擬內存頁面替換文件中創建 文件映射對象,而不是使用磁盤文件,同時必須給出這個映射對象的大小。文件映射對象通過副本,遺傳或名字來共享。
lpFileMappingAttributes:安全描述符指針,決定返回句柄是否能被子進程繼承,如果是NULL,那麼子進程不能繼承。WinNt中,如果是NULL,那麼文件映射對象得到一個默認的安全描述符。
flProtect:爲得到的文件試圖指定保護模式,可以被設置爲下列值:
PAGE_READONLY :只讀屬性,並且hFile對應的文件必須以GENERIC_READ形式打開。
PAGE_READWRITE:可讀可寫屬性,並且hFile對應的文件必須以GENERIC_READ 和 GENERIC_WRITE形式打開。
PAGE_WRITECOPY:對可寫區域複製後操作,並且hFile對應的文件必須以GENERIC_READ 和 GENERIC_WRITE形式打開。
dwMaximumSizeHigh,dwMaximumSizeLow:如果這兩個參數爲0,則文件映射對象的最大長度等於hFile指定的文件長度。
lpName: 文件映射對象的名字,如果這個名字已存在,則按照flProtect指定的來處理映射對象。如果此參數爲空,則創建一個無名字的文件映射對象。如果此參數 的名字與系統事件的名字相同,則函數執行失敗,GetLastError返回 ERROR_INVALID_HANDLE;

返回值:函數調用成功返回文件映射對象的句柄,如果文件映射對象已經存在則返回原有映射對象的句柄,GetLastError返回ERROR_ALREADY_EXISTS。函數執行失敗返回Null。

二、FlushViewOfFile 把文件映射視圖中的修改的內容或全部寫回到磁盤文件中
BOOL FlushViewOfFile(
LPCVOID lpBaseAddress,       // 修改內容的起始地址
DWORD dwNumberOfBytesToFlush // 修改的字節數目
);
函數執行成功返回非零。

三、MapViewOfFile 在調用進程的地址空間映射一個文件視圖
LPVOID MapViewOfFile(
HANDLE hFileMappingObject, // 已創建的文件映射對象句柄
DWORD dwDesiredAccess,      // 訪問模式
DWORD dwFileOffsetHigh,     // 文件偏移的高32位
DWORD dwFileOffsetLow,      // 文件偏移的低32位
DWORD dwNumberOfBytesToMap // 映射視圖的大小
);
注意:
hFileMappingObject: 由CreateFileMapping 或 OpenFileMapping 返回的文件映射對象句柄。
dwDesiredAccess:映射視圖的訪問模式,與創建文件映射對象的保護模式flProtect有關,可以被設置爲下列值:
FILE_MAP_WRITE:一個可讀寫屬性的文件視圖被創建,保護模式爲PAGE_READWRITE
FILE_MAP_READ :一個只讀屬性的文件視圖被創建,保護模式爲PAGE_READWRITE 或 PAGE_READONLY
FILE_MAP_ALL_ACCESS:與FILE_MAP_WRITE模式相同
FILE_MAP_COPY:保護模式爲PAGE_WRITECOPY時,得到一個視圖文件,當你對視圖文件寫操作時,頁面自動交換,並且你所做的修改不會損壞原始數據資料。
dwNumberOfBytesToMap:映射文件部分的大小,如果爲0,則映射整個文件。
返回值:
如果成功返回返回映射視圖的起始地址,如果失敗返回NULL。

四、MapViewOfFileEx 在調用進程的地址空間映射一個文件視圖,並且允許調用進程爲映射視圖指定特殊的內存地址
LPVOID MapViewOfFileEx(
HANDLE hFileMappingObject, // 文件映射對象的句柄
DWORD dwDesiredAccess,      // 訪問模式
DWORD dwFileOffsetHigh,     // 文件偏移的高32位
DWORD dwFileOffsetLow,      // 文件偏移的低32位
DWORD dwNumberOfBytesToMap, // 映射視圖的大小
LPVOID lpBaseAddress        // 指定映射視圖的其實內存地址
);
注意:
與MapViewOfFile用法相同,但是如果指定的內存地址空間大小不夠,則函數執行失敗。
五、OpenFileMapping 打開一個已命名的文件映射對象
HANDLE OpenFileMapping(
DWORD dwDesiredAccess, // 訪問模式
BOOL bInheritHandle,    // 繼承標誌
LPCTSTR lpName          // 文件映射對象名指針
);
注意:
dwDesiredAccess:訪問模式與MapViewOfFile中的訪問模式相同。
bInheritHandle:繼承標誌,是否可以被一個新的進程繼承使用,如果爲TRUE,就可以被一個新進程繼承句柄。
返回值:
成功返回一個已命名的文件映射對象,失敗返回NULL。

六、UnmapViewOfFile 刪除文件的映射視圖
BOOL UnmapViewOfFile(
LPCVOID lpBaseAddress   // 映射視圖起始地址
);
注意:
lpBaseAddress:映射視圖起始地址,由 MapViewOfFile 函數 MapViewOfFileEx產生。
返回值:
如果調用成功返回非零,並且所有指定地址內的髒頁面會被寫入硬盤。調用失敗返回零。

例子:
/*****************************************************/
/*                                                                               */
/*這個例子創建了文件映射視圖,並通過這個映射     */
/*視圖來操作文件內容。                                            */
/*                                                                               */
/****************************************************/
#include <stdio.h>
#include <stdlib.h>
#include <windows.h>

int main()
{
HFILE hFile;
OFSTRUCT opBuf;
HANDLE hMapfile;
HANDLE hMapview;
BYTE *recv;
hFile=OpenFile(".//map.test",&opBuf,OF_READWRITE);
if (hFile==HFILE_ERROR)
{
   printf("open file failed!/n");
   return 1;
}
hMapfile=CreateFileMapping((HANDLE)hFile,NULL,PAGE_READWRITE,0,0,"MapTest");
if(hMapfile==NULL)
{
   printf("mapping file failed!/n");
   return 1;
}
CloseHandle((HANDLE)hFile);
hFile=0;
hMapview=MapViewOfFile(hMapfile,FILE_MAP_WRITE,0,0,0);
if(hMapview==NULL)
{
   printf("mapping view failed!/n");
   return 1;
}
recv=(BYTE *)hMapview;
printf("Mapping view's content is :%.10s /n",recv);
recv[0]='s';
printf("Mapping view's content is :%.10s /n",recv);
UnmapViewOfFile(hMapview);
return 0;
}

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章