VC++中Unicode 和多字节字符集 (MBCS) 的主要区别和选择转换使用注意事项,
有些国际市场以大字符集来使用日文和中文等语言。为了支持这些市场的编程,Microsoft 基础类库 (MFC) 支持以两种方式处理大字符集:
Unicode和多字节字符集是两种不同的编码方式,不同的编码方式下,所对应的一些函数是不兼容的。
读到多字节菜单字符串之后,用MultiByteToWideChar()转为unicode字符串
或者 使用API的A版本来设置菜单的显示名称,比如,SetMenuItemInfoA(...)
如果项目是Unicode字符集调用的也是W结尾的函数,但某些参数类型为LPCTSTR,则用_T转换,比如:
改为:MessageBoxW(strTemp,_T("测试提示"), MB_ICONERROR); 则正常了
其实改起来很简单,你把所有的char都改成TCHAR,如果能用CString,尽量用CString。所有字符串函数都换上带_t的版本,比如_tsprintf()、_tcscpy之类的……因为这些东西都是同时兼容Unicode和ANSI的,所以改起来很容易。
你只要对于那些少数的多字节dll函数,参数传送字符串时实现用WideCharToMultiByte转换一下。代码如下:
//Unicode字符集以下代码可用 CString strTemp =_T(""); GetDlgItem(IDC_EDIT1)->GetWindowText(strTemp); MessageBox(strTemp); MessageBoxW(strTemp,_T("测试提示_T"), MB_ICONERROR); MessageBoxW(strTemp, L"测试提示L", MB_ICONWARNING); char szChar[64] = ""; WideCharToMultiByte(CP_ACP, 0, strTemp, wcslen(strTemp), szChar, 64, 0, 0); //CP_ACP代表ANSI代码页面 MessageBoxA(NULL, szChar, "测试窗口W2A", MB_ICONINFORMATION);
多字节编码:char,string,CStringA。
Unicode编码:wchar_t,wstring,CStringW。
注意:如果项目是Unicode,那么CString就被定义为CStringW,否则就是CStringA。
附:
LPSTR = char*;LPCSTR = const char*;
LPWSTR = wchar_t*;LPCWSTR = const wchar_t*;
至于LPCTSTR也是根据项目字符集来定义为LPCWSTR(Unicode)或LPCSTR(多字节)。
本文来自博客园,作者:IT情深,转载请注明原文链接:https://www.cnblogs.com/wh445306/p/16751805.html
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· DeepSeek 开源周回顾「GitHub 热点速览」
· 物流快递公司核心技术能力-地址解析分单基础技术分享
· .NET 10首个预览版发布:重大改进与新特性概览!
· AI与.NET技术实操系列(二):开始使用ML.NET
· 单线程的Redis速度为什么快?