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; }
。。。。。。。。。。。。结束。。。。。。。。。。。。。。。