纯属自己的理解,不对的请提出
wchar_t和char相比,都是存放一个字符,但是前者可以存储一个中文汉字,后者因为在C++中是不能的
TCHAR类型,既可以存放wchar_t类型又可以存放char类型,其实TCHAR具体是什么类型,是_UNICODE宏决定的,大概是为了,只用修改宏,就可以改变项目中实际的TCHAR代表的到底是wchar_t类型还是char类型.
一般来说,
char a ='A';
wchar_t* a=L"A";
都是存储了'A'这个字符.
还有一种,
TCHAR * a = L"AA";
TCHAR a[] = _T("AA");
都存储了"AA"这个字符串.前一种TCHAR其实是wchar_t 类型,而_T()函数,会根据_UNICODE宏,来决定TCHAR 类型到底是char类型还是wchar_t类型.
下面的代码是网上找的,试过了,可以在vs2015中读和写中文txt文件,搞了几天都没搞懂的读取中文txt,就这么被解决了
#include<iostream>
#include <fstream>
#include <locale>
struct record
{
wchar_t id[9];
wchar_t name[3];
float score;
};
int main()
{
record r[] = {
{L"12345678", L"张三", 98.3f},
{L"87654321", L"李四", 89.66f},
{L"76778981", L"王五", 89.6778f}
};
std::locale chs("chs"); //处理中文字符
//output
{
std::wofstream ofs("data.txt");
ofs.imbue(chs);
for (int i = 0; i < sizeof(r)/sizeof(r[0]); i++)
{
ofs << r[i].id << L"##" << r[i].name << L"##" <<
r[i].score << std::endl;
}
}
//input
{
std::wifstream ifs("data.txt");
ifs.imbue(chs);
std::wcout.imbue(chs);
std::wstring line;
while(std::getline(ifs, line))
{
std::wcout << line << std::endl;
}
}
return 0;
}