真的很惭愧,竟然没搞懂“在程序里wstring,string和CString的Buffer里到底存的是什么”这种菜鸟级的问题
分别在字符集为MuiltiByte和Unicode下的程序进行测试
结果如下:
MuiltiByte程序里
int main()
{
string tmpStr = "abc"; //MuiltiByte
wstring tmpStr3 = L"abc"; //Unicode
string tmpStr1 = "一二"; //MuiltiByte
wstring tmpStr2 = L"一二"; //Unicode
char tmpCArr[255];
memset(tmpCArr,0,255);
WideCharToMultiByte(CP_ACP, 0, (LPCWSTR)tmpStr2.c_str(), tmpStr2.length(), tmpCArr, 255, NULL, NULL) ;
WCHAR tmpCArr1[255];
memset(tmpCArr1,0,sizeof(tmpCArr1));
MultiByteToWideChar(CP_ACP,NULL,tmpStr1.c_str(),tmpStr1.length(),tmpCArr1,255);
CString tmpCStr1("一二"); //MuiltiByte
CString tmpCStr2(L"一二"); //MuiltiByte
CString tmpCStr3(_T("一二")); //MuiltiByte
CString tmpCStr4("abc"); //MuiltiByte
CString tmpCStr5(L"abc"); //MuiltiByte
CString tmpCStr6(_T("abc")); //MuiltiByte
}
Unicode程序里
int main()
{
string tmpStr = "abc"; //MuiltiByte
wstring tmpStr3 = L"abc"; //Unicode
string tmpStr1 = "一二"; //MuiltiByte
wstring tmpStr2 = L"一二"; //Unicode
char tmpCArr[255];
memset(tmpCArr,0,255);
WideCharToMultiByte(CP_ACP, 0, (LPCWSTR)tmpStr2.c_str(), tmpStr2.length(), tmpCArr, 255, NULL, NULL) ;
WCHAR tmpCArr1[255];
memset(tmpCArr1,0,sizeof(tmpCArr1));
MultiByteToWideChar(CP_ACP,NULL,tmpStr1.c_str(),tmpStr1.length(),tmpCArr1,255);
CString tmpCStr1("一二"); //Unicode
CString tmpCStr2(L"一二"); //Unicode
CString tmpCStr3(_T("一二")); //Unicode
CString tmpCStr4("abc"); //Unicode
CString tmpCStr5(L"abc"); //Unicode
CString tmpCStr6(_T("abc")); //Unicode
}
结论:
在不同的字符集下 string 和 wstring的行为都是一样的,string永远都是存MuiltiByte而wstring永远都是存Unicode,
而CString都是根据你这个程序的字符集决定的。