WriteFile()MFC

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

複製代碼

參數說明:緩存


HANDLE hFile 文件句柄app

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

LPCVOID lpBuffer 數據緩存區指針ide

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

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

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

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

問題:
使用WriteFile的時候,我直接將寬字符串寫進了文件,文件顯示如你們所想,摻雜了不少亂碼。可是頗有規則。因此我很快就明白了這須要將寬字符串轉換成ASCII碼。it

解決方法:
把寬字符串轉換成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;
}
相關文章
相關標籤/搜索