#include <string>
#include <locale.h>
using namespace std;
string ws2s(const wstring& ws)
{
string curLocale = setlocale(LC_ALL, NULL); // curLocale = "C";获得当前的 Local
setlocale(LC_ALL, "chs");
const wchar_t* _Source = ws.c_str();
。。。
wcstombs(_Dest,_Source,_Dsize);
。。。
setlocale(LC_ALL, curLocale.c_str()); // 恢复Local
return result;
//代码参考自 http://blog.csdn.net/code_pipeline/archive/2007/11/02/1863665.aspx
}
现在我的理解是对于unicode,它的形式是双字节,但是要对这些双字节做出正确的解释,是需要正确的page页的,比如:setlocale(LC_ALL, "C"),只是以ansi页来解释,而setlocale(LC_ALL, "chs")是以gbk页码来翻译为中文的双字节。而过程就是mbstowcs,这个单字节转双字节函数。