http://127.0.0.1:47873/help/1-1412/ms.help?method=page&id=E7E4F741-3C82-45F0-B8C0-1E1E343B0E77&product=VS&productVersion=100&topicVersion=100&locale=ZH-CN&topicLocale=ZH-CN
CString 基于 TCHAR 数据类型,而后者又依赖于是否定义了
_UNICODE 符号。
如果未定义
_UNICODE,则
TCHAR 定义为 char 且
CString 包含一个多字节字符字符串;如果定义了
_UNICODE,则
TCHAR 定义为
wchar_t 且
CString 包含一个宽字符字符串。
CStringA
是
CString
的多字节字符串的始终版本;
CStringW
是宽字符字符串的唯一版本。
CStringA 和
CStringW 都不使用
_UNICODE 确定它们应采用的编译方式。
此示例使用
CStringA 和
CStringW 明确指定缓冲区大小分配和输出处理中的一些细微差异。
多字符情况编码:
CString -> *char -> CString
m_cstr -> pch -> ctemp
const size_t newsizea = (m_cstr.GetLength() + 1);
char *pch = new char[newsizea];
strcpy_s(pch, newsizea, m_cstr); //CString 转 char 直接复制
CString ctemp(pch); //char 转 CString
m_cstr -> pch -> cstring
方法1
const size_t newsizew = (m_cstr.GetLength() + 1)*2;
char *nstringw = new char[newsizew];
size_t convertedCharsw = 0;
wcstombs_s(&convertedCharsw, nstringw, newsizew, m_cstr, _TRUNCATE ); // m_cstr --> ch
CString cstring(nstringw);//char 转 CString
方法2,
const size_t newsizew = (m_cstr.GetLength() + 1)*2; //
char *ch = new char[newsizew];
WideCharToMultiByte(CP_OEMCP,NULL,m_cstr,-1,ch,newsizew,0,NULL);// m_cstr --> ch
CString cstring(ch); //ch --> cstring
char 转WCHAR
char ch[2];
sprintf(ch, "%c", wParam);
WCHAR p[2];
MultiByteToWideChar(CP_ACP, 0, ch, 2, p, 2);