遇到的问题
\quad
我们在使用MFC开发的时候会遇到字符集的问题。使用ANSI和UNICODE对于显示中文的时候就会出现不一样。ANSI是用一个字节表示一个字符,显示中文的时候就会出现乱码。
\quad
现在Visual Studio的最新的VC142平台工具集已经默认只使用UNICODE字符集了。但是难免有些旧的代码当时写的时候,VS同时支持多字节字符集(MBCS)和UNICODE,例如VC140就支持这两种字符集。多字节字符集和UNICODE字符集的区别就是,UNICODE每个字符都用两个字节表示,多字节字符集对于每个字符的表示就不确定,可能会占用1、2、3个等。这就是这两个的区别。
\quad
我们可以感觉到MBCS这样就很麻烦,UNICODE的出现部分是为了解决这个问题。
解决方法
我们知道,对于英文的话,就是使用的一个字节,几种字符集都没有问题。但是表示中文的话,就很麻烦了。但是MFC给我们提供了一个便捷的解决方案。就是使用_T宏。如:
int nRet = MessageBox(NULL,_T("这是我开发的\nWindows程序"),_T("温馨提示"),MB_OKCANCEL | MB_ICONINFORMATION);
这里面显示的中文内容都加了_T宏,一方面这里函数的参数就是有这个要求(在VC142平台工具集下),另一方面,显示中文这么写才是合理的,不然会乱码。当然,这是建立在使用UNICODE字符集的基础上,如果使用多字节字符集(MBCS)的话,就可以不用加_T宏也没关系。但是,随着时代的发展,使用UNICODE是趋势,应该尽量使用UNICODE字符集。再说了,加了_T的话,在MBCS上是可以运行的。所以,我建议选择这个兼容性高的。