解决CFile输出汉字为乱码的问题

使用CFile操作文件十分方便,但是却会遇到输出汉字到文件后变成乱码的困扰

在网上搜索解决方案得到的结果大多如下:

1.选择多字节模式编译程序  2.使用WideCharToMultiByte函数将宽字符转换为窄字符再输出

例如下面的代码在多字节编译模式下能输出汉字到文件

[cpp] view plain copy print ?
  1. CFile fileout; 
  2. fileout.Open(_T("report.txt"),CFile::shareExclusive|CFile::modeWrite|CFile::modeCreate); 
  3.  
  4. CString strTitle= _T("汉字汉字/r/n"); 
  5.  
  6. fileout.Write(strTitle.GetBuffer(), strTitle.GetLength()); 
CFile fileout; fileout.Open(_T("report.txt"),CFile::shareExclusive|CFile::modeWrite|CFile::modeCreate); CString strTitle= _T("汉字汉字/r/n"); fileout.Write(strTitle.GetBuffer(), strTitle.GetLength());

但是很多情况下我们都希望使用UNICODE模式编译,同时我们也会有疑问,难道就不能把unicode的字符正常输出到文件里面吗?

网上流行的答案显然没有命中问题的要害!其实,unicode字符已经被Cfile忠实地输入了文件当中!遗憾的是字处理软件(如:记事本)不知道其中是unicode字符,将他们统统当做了单字节字符处理。

要想让字处理软件识别unicode必须在文件头上加入unicode编码的前导字符:0xff, 0xfe

于是,可以用下面的代码实现汉字的输出且用字处理软件打开不会乱码

[c-sharp] view plain copy print ?
  1. #difine TCHARLEN (sizeof(TCHAR)) // 一个字符占的字节数 
  2.  
  3. CFile fileout; 
  4. fileout.Open(_T("report.txt"),CFile::shareExclusive|CFile::modeWrite|CFile::modeCreate); 
  5.  
  6. ULONGLONG dwFileLen = fileout.GetLength(); 
  7. if (0 == dwFileLen) // 文件为空时写入UNICODE字节序标记 
  8.     const unsigned char LeadBytes[]  = {0xff, 0xfe}; 
  9.     fileout.Write(LeadBytes, sizeof(LeadBytes)); 
  10.  
  11. CString strTitle; 
  12. strTitle = _T("汉字汉字/r/n"); 
  13.  
  14. fileout.Write(strTitle.GetBuffer(), strTitle.GetLength()*TCHARLEN);// 注意:输出的字节数与字符数并不一致 
#difine TCHARLEN (sizeof(TCHAR)) // 一个字符占的字节数 CFile fileout; fileout.Open(_T("report.txt"),CFile::shareExclusive|CFile::modeWrite|CFile::modeCreate); ULONGLONG dwFileLen = fileout.GetLength(); if (0 == dwFileLen) // 文件为空时写入UNICODE字节序标记 { const unsigned char LeadBytes[] = {0xff, 0xfe}; fileout.Write(LeadBytes, sizeof(LeadBytes)); } CString strTitle; strTitle = _T("汉字汉字/r/n"); fileout.Write(strTitle.GetBuffer(), strTitle.GetLength()*TCHARLEN);// 注意:输出的字节数与字符数并不一致

打完,收工.......

你可能感兴趣的:(解决CFile输出汉字为乱码的问题)