在PC硬體體系結構裡,速度最快的存儲器是CPU裡面的寄存器,接着到二級緩存,再到系統RAM記憶體,最後才到硬碟。因為這種體系結構,就決定了作業系統對檔案的操作方式,或者說是最優化的算法。比方作業系統接收到寫檔案的資料時,就會先把資料儲存到RAM裡,然後在合适的時間或者合适的資料量時再寫到硬碟裡。但有時候我們希望資料一定要儲存到硬碟裡,而不是儲存在RAM裡,這時就須要使用函數FlushFileBuffers來把RAM裡的資料儲存到硬碟裡。檔案的結構是一個有序的隊列,有頭有尾,當讀寫檔案後,就會移動檔案中的檔案指針。有時候想移動到特定的位置讀取資料。比方讀取一個BMP的檔案,它有檔案頭和資料塊組成,就須要先讀取檔案頭,然後依據檔案頭裡訓示資料塊開始位置去讀取圖檔顯示資料,這時就須要使用到SetFilePointer函數。
函數FlushFileBuffers和SetFilePointer聲明例如以下:
WINBASEAPI
BOOL
WINAPI
FlushFileBuffers(
__in HANDLE hFile
);
DWORD
SetFilePointer(
__in HANDLE hFile,
__in LONG lDistanceToMove,
__in_opt PLONG lpDistanceToMoveHigh,
__in DWORD dwMoveMethod
hFile是檔案句柄。
lDistanceToMove是檔案指針距離頭或尾的長度。
lpDistanceToMoveHigh是檔案指針距離頭或尾的長度高位長度。
dwMoveMethod是相對檔案頭、檔案尾或者目前位置的方式。
調用函數的樣例例如以下:
#001 //建立、寫入、讀取檔案。
#002 //蔡軍生 2007/10/21 QQ:9073204 深圳
#003 void CreateFileDemo(void)
#004 {
#005 //
#006 HANDLE hFile = ::CreateFile(_T("CreateFileDemo.txt"), //建立檔案的名稱。
#007 GENERIC_WRITE|GENERIC_READ, // 寫和讀檔案。
#008 0, // 不共享讀寫。
#009 NULL, // 預設安全屬性。
#010 CREATE_ALWAYS, // 假設檔案存在,也建立。
#011 FILE_ATTRIBUTE_NORMAL, // 一般的檔案。
#012 NULL); // 模闆檔案為空。
#013
#014 if (hFile == INVALID_HANDLE_VALUE)
#015 {
#016 //
#017 OutputDebugString(_T("CreateFile fail!/r/n"));
#018 }
#019
#020 //往檔案中寫資料。
#021 const int BUFSIZE = 4096;
#022 char chBuffer[BUFSIZE];
#023 memcpy(chBuffer,"Test",4);
#024 DWORD dwWritenSize = 0;
#025 BOOL bRet = ::WriteFile(hFile,chBuffer,4,&dwWritenSize,NULL);
#026 if (bRet)
#027 {
#028 //
#029 OutputDebugString(_T("WriteFile 寫檔案成功/r/n"));
#030 }
#031
#032 //先把寫檔案緩沖區的資料強制寫入磁盤。
#033 FlushFileBuffers(hFile);
#034
#035 //
#036 //從檔案中讀取資料。
#037 LONG lDistance = 0;
#038 DWORD dwPtr = SetFilePointer(hFile, lDistance, NULL, FILE_BEGIN);
#039 if (dwPtr == INVALID_SET_FILE_POINTER)
#040 {
#041 //擷取出錯碼。
#042 DWORD dwError = GetLastError() ;
#043 //處理出錯。
#044 }
#045
#046 DWORD dwReadSize = 0;
#047 bRet = ::ReadFile(hFile,chBuffer,4,&dwReadSize,NULL);
#048 if (bRet)
#049 {
#050 //
#051 OutputDebugString(_T("ReadFile 讀檔案成功/r/n"));
#052 }
#053 else
#054 {
#055 //擷取出錯碼。
#056 DWORD dwError = GetLastError();
#057 //處理出錯。
#058 TCHAR chErrorBuf[1024];
#059 wsprintf(chErrorBuf,_T("GetLastError()=%d/r/n"),dwError);
#060 OutputDebugString(chErrorBuf);
#061 }
#062
#063 }