函數原型: 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; }