我们在编写Visual C++ 2005程序时候经常会碰到(如下错误),很迷惑
'CreateWindowExW' : cannot convert parameter 1 from 'const char [4]' to 'LPCWSTR'
UNICODE  计算机发明后,为了在计算机中表示字符,人们制定了一种编码,叫ASCII码。ASCII码由一个字节中的7位(bit)表示
,范围是0x00 - 0x7F 共128个字符。他们以为这128个数字就足够表示abcd....ABCD....1234 这些字符了。
咳......说英语的人就是“笨”!后来他们突然发现,如果需要按照表格方式打印这些字符的时候,缺少了“制表符”。于是又扩展了ASCII的定义,使用一个字节的全部8位(bit)来表示字符了,这就叫扩展ASCII码。范围是0x00 - 0x
FF 共256个字符。
咳......说中文的人就是聪明!中国人利用连续2个扩展ASCII码的扩展区域(0xA0以后)来表示一个汉字,该方法的
标准叫GB-2312。后来,日文、韩文、阿拉伯文、台湾繁体(BIG-5)......都使用类似的方法扩展了本地字符集的定义,
现在统一称为 MBCS 字符集(多字节字符集。既:有2 个字节的字符,也有1个字节的字符)。这个方法是有缺陷的,因为
各个国家地区定义的字符集有交集,因此使用GB-2312的软件,就不能在BIG-5的环境下运行(显示乱码,因为:阿拉伯人
在机器上编写的阿拉伯文字,经过机器的字符编码,变成了一个特定的0x XXXX,而这个特定的0x XXXX字符到中国人的机
器上却不存在相对应的汉字,或者是相对应出的汉字 根本就与原来阿拉伯文字文章一点关系没有的,所以出现乱码),反
之亦然。
咳......说英语的人终于变“聪明”一些了。为了把全世界人民所有的所有的文字符号都统一进行编码,于是制定了UNICODE标准字符集。UNICODE 使用2个字节表示一个字符(unsigned shor int、WCHAR、_wchar_t、OLECHAR)。这下终
于好啦,全世界任何一个地区的软件,可以不用修改地就能在另一个地区运行了。虽然我用 IE 浏览日本网站,显示出我
不认识的日文文字,但至少不会是乱码了。UNICODE 的范围是 0x0000 - 0xFFFF 共6万多个字符,其中光汉字就占用了4
万多个。嘿嘿,中国人赚大了。
在程序中使用各种字符集的方法:
const char * p = "Hello"; // 使用 ASCII 字符集
const char * p = "你好"; // 使用 MBCS 字符集,由于 MBCS 完全兼容 ASCII,多数情况下,我们并不严格区
分他们
LPCSTR p = "Hello,你好"; // 意义同上
const WCHAR * p = L"Hello,你好"; // 使用 UNICODE 字符集
LPCOLESTR p = L"Hello,你好"; // 意义同上
// 如果预定义了_UNICODE,则表示使用UNICODE字符集;如果定义了_MBCS,则表示使用 MBCS
const TCHAR * p = _T("Hello,你好");
LPCTSTR p = _T("Hello,你好"); // 意义同上
在上面的例子中,T是非常有意思的一个符号(TCHAR、LPCTSTR、LPTSTR、_T()、TEXT()、_TEXT()...),它表示使
用一种中间类型,既不明确表示使用 MBCS,也不明确表示使用 UNICODE。那到底使用哪种字符集那?嘿嘿......编译的时候决定吧。设置条件编译的方式是:VC6中,"Project\Settings...\C/C++卡片 Preprocessor definitions" 中添加或修改 _MBCS、_UNICODE;VC.NET中,"项目\属性\配置属性\常规\字符集"然后用组合窗进行选择。使用 T 类型,是非常
好的习惯,严重推荐!
举个例子:
"abc"是非Unicode  string,
L"abc"是Unicode tring.     L用来定义UNICODE字符串,L就是转换成宽字符
其次:.NET  的平台CLR (Common Language  RunTime库中用定义(#define)  _UNICODE  来表示使用Unicode;
在  Win32  API 中是用定义(#define)  UNICODE  来表示使用 Unicode 。  
而大多数应用程序(Application)都是既使用CLR又使用Win32  API的,所以一般地,_UNICODE和UNICODE  应该在工程
中同时定义或同时不定义。
_T("abc") 在_UNICODE已定义时解释成L"abc",是Unicode string;
在_UNICODE 未定义时则解释成"abc",非Unicode  string。
TEXT("abc")类似,不过它是根据UNICODE 的定义与否来决定的。
再说以下:
如果有下面三句话:  
TCHAR   szStr1[]   =   TEXT("str1");  
char   szStr2[]   =   "str2";  
WCHAR   szStr3[]   =   L("str3");  
那么第一句话在定义了UNICODE时会解释为第三句话,没有定义时就等于第二句话。   
第二句话无论是否定义了UNICODE都是生成一个ANSI字符串,而第三句话总是生成UNICODE字符串。  
为了程序的可移植性,建议都用第一中表示方法。
MultiByteToWideChar函数与 _T、TEXT() 这两个宏都可以选择 ASNI (MBCS) 还是 UNICODE 字符
第一个函数转换的对象可以是常量、变量;第二、三只能转换常量。 
补充:
LPSTR   ==   char* 

LPCSTR   ==   const   char*

LPCTSTR   ==   const   char*   //   Not   defined   _UNICODE,   such   as   win9x  

LPCTSTR   ==   const   wchar_t*   //   defined   _UNICODE,   such   as   win2k

LPWSTR   ==   wchar_t*
即:
LPCSTR    A  32-bit   pointer   to   a   constant   character   string.
LPSTR     A  32-bit   pointer   to   a   character   string.

LPCTSTR   A  32-bit pointer to a constant character string that is portable for Unicode and DBCS.

LPTSTR    A 32-bit   pointer   to   a   character   string   that   is   portable   for   Unicode   and   DBCS.
另外,如果嫌类型转换实在太麻烦的话,就把字符集设成“未设置”,修改之后通常需要清理解决方案,再重新生成,
否则会出现错误:general error c101008a: Failed to save the updated manifest to the file ".\Debug\Test1.exe.embed.manifest". The parameter is incorrect.    mt.exe

VS2005中UNICODE和ANSI以及MBCS的问题相关推荐

  1. python读取ansi编码文件,如何在Python中同时读取ANSI和Unicode txt文件?

    我是python新手,遇到了一个奇怪的问题: 当一个目录中有50个txt文件时,我希望读取每个.txt文件并将其内容保存在一个唯一的变量中,例如:**file = open(fcf[i], 'r') ...

  2. 移植性问题のCString类型转换,字符串操作和UNICODE、ANSI字符集

    一.CString与LPCWSTR 两者的不同:LPCWSTR 是Unicode字符串指针,初始化时串有多大,申请空间就有多大,以后存贮若超过则出现无法预料的结果,这是它与CString的不同之处.而 ...

  3. 有关UNICODE、ANSI字符集和相关字符串操作的总结[转]

    Q UNICODE字符串如何显示 A 如果程序定义了_UNICODE宏直接用 WCHAR *str=L"unicodestring"; TextOut(0,0,str); 否则就需 ...

  4. vc6.0转vs2005中字符串的问题

    简单一点:就是project->Property->Configuration Property-->general-->Character Set:No Set即可.详细分析 ...

  5. UNICODE与ANSI的区别

    帮同学写个播放音乐的代码,用的是vs2005,本来调用下API中的mciSendSrring()就很容易解决,后发现老是有warning: incompatible types - from 'cha ...

  6. 为什存在_tmain以及Unicode和ANSI

    main()是标准C++的函数入口.标准C++的程序入口点函数,默认字符编码格式ANSI 函数签名为: int main(); int main(int argc, char* argv[]);_tm ...

  7. VB中Unicode vs Ansi-From alpsong(阿尔卑斯之歌)

    Unicode vs Ansi Visual Basic 32-bit 版本的字串处理采用 Unicode,也就是说字串在 VB 内部是以 Unicode 的格式来存放. 何谓 Unicode?简单的 ...

  8. Unicode和ANSI之间转换 - NotePad++轻松实现

    今天碰到一个关于UNICODE和ANSI相互转换的问题,作为一个程序员,我首先想到的是用WideCharToMultiByte/MultiByteToWideChar实现,这个我想大家都会了,我也会在 ...

  9. 介绍一下unicode,ansi,utf-8,unicode big endian编码

    介绍一下unicode,ansi,utf-8,unicode big endian编码 很久很久以前,有一群人,他们决定用8个可以开合的晶体管来组合成不同的状态,以表示世界上的万物.他们看到8个开关状 ...

  10. 字符集和编码 UNICODE、ANSI、UTF-8、GB2312 都是什么鬼

    这是我在网上看到的一篇通俗易懂的教程,但是无法找到原作者的署名,故直接搬过来了 不是本人所作,特此声明 快下班时,爱问问题的小朋友Nico又问了一个问题: "sqlserver里面有char ...

最新文章

  1. redis缓存存在的隐患及其解决方案
  2. 蛋疼的mocha库-promise异步测试
  3. 如何将SP1集成到Office 2007安装包
  4. Ubuntu 14.04.5 imx6 开发环境搭建
  5. 【转】ubuntu,你改变了我的人生
  6. List中toArray()的使用方法
  7. CSS中em和px单位的区别(转)
  8. Blender建模与游戏换装(转载文)
  9. linux c之((void *) - 1)是啥意思
  10. php的功能和特点,php的特点有哪些
  11. 将 Excel 导入到 SharePoint 列表
  12. Keil综合(02)工程窗口各项图标描述
  13. iOS企业证书申请介绍
  14. tomcat设置context不生效_后端服务:关于Tomcat相关面试题,看懂这篇就够了(有深度)...
  15. 小凡的Python之路——安装
  16. MATLAB基本介绍(1)
  17. 从Q2财报,看携程的内容“元宇宙”
  18. DES加密算法(框图流程详细分析)(C++实现)
  19. 俄亥俄州立大学计算机科学转学成功,托福97,我是如何转学成功的?
  20. [机器学习必知必会]泛化误差率的偏差-方差分解

热门文章

  1. PHP - 使用file_get_contents下载远程文件到本地
  2. excel中复制时不要计算机,电脑excel表格中无法将复制的内容粘贴进去如何解决...
  3. 解决Linux终端无法复制粘贴现象
  4. java中case怎么用,Java中case使用示例,Javacase使用示例,switch([vari
  5. 厦门大学计算机科学夏令营过程,厦门大学信息学院计算机系夏令营学生见面会如期召开-厦门大学计算机科学系...
  6. 整理了 47 个 Python 人工智能库
  7. win10 按用户名访问计算机,win7访问win10系统时需要输入用户名密码的两种解决方法...
  8. 免费文献下载地址汇总
  9. 2019年山东计算机单招学校,2019年山东单招学校排名前十的有哪些?
  10. sqli-labs48关_Open Labs带来48小时骇客马拉松