在Unicode编码模式下,向文件里写汉字时会出现乱码的情况。 出现乱码说明字符已经被写入到文件里,只是用文件编辑器打开文件的时候不知道是其内容是Unicode字符,统统将其中的字符做为单字节字符出来,所以出现乱码。以下提供两种解决方法供参考。
(一)在文件的开头写入0xff, 0xfe.
写入0xff,0xfe只是告诉文字编制软件将文件内的内容做Unicode字符处理。
代码:
char buf[] = {0xff,0xfe};
File.Write(buf, 2);
写其他字符串:
File.Write(str, str.GetLength() *2);
如果需要换行则在str后面加上_T("\r\n");
(二)Setlocal()设定区域编码字符
char * old_local = _strdup(setlocale(LC_CTYPE, NULL));
setlocale(LC_CTYPE, "chs");
...
setlocale(LC_CTYPE, old_local);
delete old_local;