N:代表near,在16位系统中代表16位的段内地址
L:代表long(far),在16位系统中代表16位的段地址+16位的偏移地址
在32位系统中 N和L已经没有作用,只是为了向前兼容(兼容16位机器)才保留这些定义。
P:代表指针
C:代表CONST(const)
W:代表WCHAR(wchar_t)
T:代表宏_T(一个兼容的宏,当定义了UNICODE或者_UNICODE是表示WCHAR,否则表示char)
CH:char的简写
STR:string的简写
LPSTR (ANSI)字符串变量
LPCSTR (ANSI)字符串常量
LPCTSTR (Unicode)如果定义了UNICODE宏,则是LPCWSTR,否则是LPCSTR
LPTSTR (Unicode)字符串变量
其中StackExchange中有:
LPSTR
=char*
LPCSTR
=const char*
LPWSTR
=wchar_t*
LPCWSTR
=const wchar_t*
LPTSTR
=char* or wchar_t*
depending on_UNICODE
LPCTSTR
=const char* or const wchar_t*
depending on_UNICODE
原文:http://programmers.stackexchange.com/questions/194764/what-is-lpctstr
string转化为LPSTR直接强制转化即可
string转化为LPCSTR
string a;
LPCSTR b;
b = a.c_str();
string转化为LPCWSTR
LPCWSTR ChangeToLPCWSTR(string orig)
{
size_t origsize = orig.length() + 1;
const size_t newsize = 100;
size_t convertedChars = 0;
wchar_t *wcstring = (wchar_t *)malloc(sizeof(wchar_t)*(orig.length() - 1));
mbstowcs_s(&convertedChars, wcstring, origsize, orig.c_str(), _TRUNCATE);
std::wstring wstrResult(wcstring);
free(wcstring);
return wstrResult.c_str();
}
{
size_t origsize = orig.length() + 1;
const size_t newsize = 100;
size_t convertedChars = 0;
wchar_t *wcstring = (wchar_t *)malloc(sizeof(wchar_t)*(orig.length() - 1));
mbstowcs_s(&convertedChars, wcstring, origsize, orig.c_str(), _TRUNCATE);
std::wstring wstrResult(wcstring);
free(wcstring);
return wstrResult.c_str();
}
常量转化为LPCWSTR可以用L,_T(),TEXT()
*************************************未完待定**************************************