https://www.cnblogs.com/yuguangyuan/p/5955959.html

没有定义UNICODE,所以它里面的字符串就是简单用" "就行了,创建工程的时候包含了UNICODE定义,就必须对TCHAR和char进行转换。

void TcharToChar(const TCHAR * tchar, char * _char)
{
int iLength;
//获取字节长度
iLength = WideCharToMultiByte(CP_ACP, , tchar, -, NULL, , NULL, NULL);
//将tchar值赋给_char
WideCharToMultiByte(CP_ACP, , tchar, -, _char, iLength, NULL, NULL);
} void CharToTchar(const char * _char, TCHAR * tchar)
{
int iLength;
iLength = MultiByteToWideChar(CP_ACP, , _char, strlen(_char) + , NULL, );
MultiByteToWideChar(CP_ACP, , _char, strlen(_char) + , tchar, iLength);
}

表明 TCHAR 与 WCHAR 属同一类型
char szA[100];                    // ANSI string buffer
WCHAR szW[100];            // Unicode string buffer
// Normal sprintf:all strings are ANSI
sprintf(szA, "%s","ANSI Str");
// Converts Unicode string to ANSI
sprintf(szA,"%S",L"Unicode Str");
// Normal swprintf:all strings are Unicode
swprintf(szW,L"%s",L"Unicode Str");
// Converts ANSI string to Unicode
swprintf(szW,L"%S", "ANSI Str");
注意:大写S 和小写s 的使用

string 转lpcwstr

    LPCWSTR stringToLPCWSTR(std::string orig)
{
wchar_t *wcstring = ;
try{
size_t origsize = orig.length() + ;
const size_t newsize = ;size_t convertedChars = ;
if (orig == ""){wcstring = (wchar_t *)malloc();
mbstowcs_s(&convertedChars, wcstring, origsize, orig.c_str(), _TRUNCATE);
}
else{
wcstring = (wchar_t *)malloc(sizeof(wchar_t)*(orig.length() - ));
mbstowcs_s(&convertedChars, wcstring, origsize, orig.c_str(), _TRUNCATE);
}
}
catch (std::exception e)
{}
return wcstring;
}
std::string to_s(LPCWSTR ws)
{
DWORD length = WideCharToMultiByte(CP_OEMCP, NULL, ws, -, NULL, , NULL, FALSE);
std::string result(length, );
WideCharToMultiByte(CP_OEMCP, NULL, ws, -, &result[], length, NULL, FALSE);
result.erase(result.size() - , );
return result;
} std::wstring to_ws(LPCSTR str)
{
int length = MultiByteToWideChar(GetACP(), , str, -, NULL, );
std::wstring result(length, );
MultiByteToWideChar(GetACP(), , str, -, &result[], length);
return result;
}
05-11 15:24
查看更多