WriteFile()----同步


函數原型:
BOOL WriteFile
(
HANDLE  hFile,
LPCVOID lpBuffer,//
DWORD   nNumberOfBytesToWrite,
LPDWORD lpNumberOfBytesWritten,
LPOVERLAPPED lpOverlapped//OVERLAPPED
);

參數說明:


HANDLE hFile 文件句柄

  注意:如果文件打開方式沒有指明FILE_FLAG_OVERLAPPED的話,當程序調用成功時,它將實際寫入文件的字節數保存到lpNumberOfBytesWriten指明的地址空間中

LPCVOID lpBuffer 數據緩存區指針

  指針,指向將寫入文件的數據緩沖區

DWORD nNumberOfBytesToWrite 字節數
  要寫入數據的字節數量。如寫入零字節,表示什么都不寫入,但會更新文件的“上一次修改時間”。針對位於遠程系統的命名管道,限制在65535個字節以內

LPDWORD lpNumberOfBytesWritten  用於保存實際寫入字節數的存儲區域的指針
  實際寫入文件的字節數量(此變量是用來返回的 )

LPOVERLAPPED lpOverlapped//OVERLAPPED 結構體指針
  倘若在指定FILE_FLAG_OVERLAPPED的前提下打開文件,指針不能為空,這個參數就必須引用一個特殊的結構。那個結構定義了一次異步寫操作。否則,該參數應置為空(將聲明變為ByVal As Long,並傳遞零值)。

問題:
使用WriteFile的時候,我直接將寬字符串寫進了文件,文件顯示如大家所想,摻雜了很多亂碼。但是很有規則。所以我很快就明白了這需要將寬字符串轉換成ASCII碼。

解決方法:
把寬字符串轉換成ASCII碼。我們需要將pBuffer進行轉換。這就要用到了WideCharToMultiByte
改進后:
char* pchBuffer = new char[dwLen+1];
WideCharToMultiByte(CP_ACP, NULL, pBuffer, -1, pchBuffer, dwLen+1, NULL, FALSE );
WriteFile(hFile, pBuffer, dwLen+1, &dwSize, NULL );
Delete[] pchBuffer;

代碼:
BOOL WriteOwnFile(TCHAR* pFileName, TCHAR* pBuffer)

{

  HANDLE hFile = CreateFile(
        pFileName,
        GENERIC_WRITE,
        FILE_SHARE_WRITE,
        NULL,
        CREATE_ALWAYS,
        FILE_ATTRIBUTE_NORMAL,
        NULL
        );
 
  if(hFile == INVALID_HANDLE_VALUE)
    {
        MessageBox(NULL, "打開文件失敗", "Error", MB_OK);
        CloseHandle((hFile);        //一定注意在函數退出之前對句柄進行釋放。
        return;
    }

   DWORD dwSize = 0;

   //把寬字符串轉換成ASCII碼
   DWORD dwLen = WideCharToMultiByte(CP_ACP, NULL, pBuffer, -1, NULL, NULL, NULL, FALSE );
   char* pchBuffer = new char[dwLen];
   WideCharToMultiByte(CP_ACP, NULL, pBuffer, -1, pchBuffer, dwLen, NULL, FALSE );
   //轉換后再進行寫入 dwLen+1 因為ASCII碼后有結束符'\0';
   WriteFile(hFile, pBuffer, dwLen+1, &dwSize, NULL );
   delete[] pchBuffer;
  
   CloseHandle(hFile);
   return TRUE;
}

。。。。。。。。。。。。結束。。。。。。。。。。。。。。。

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM