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;
}

。。。。。。。。。。。。结束。。。。。。。。。。。。。。。

 

posted @ 2017-05-29 18:48  gd_沐辰  阅读(5299)  评论(0编辑  收藏  举报