开始用ansi编码之后,在保存到unicode之后字符将丢失,原因:
ansi 是用8bit 码,而对于ascii来讲,其实只用了7bit
unicode是用16bit码
ansi是以单字节来保存英文字符,以双字节来保存中文字符
unicode都是以双字节保存中英文字符的
在com中,只支持unicode
1双字节中,一个字符可以包含两个字节,也可以包含1个字节,由于软件本地化的问题,所以出现了双字节(DBCS)
Unicode:是有apple和xerox在1988年建立的一个技术标准,每个unicode都是两个字节(16为),总共有65000字符。
2若一个内存中字符,怎么判断他是ansi还是unicode,可以使用charnext,charprev以及IsDBCSLeadbyte的函数,若对于unicode而言,
不需要在判断第一个字符是否是双字节,直接调用charnext即可
3为什么要使用本地化
很容易在不同语语言中进行转换
提高程序的运行效率
使您能够分配多种语言的2进制文件和dll
4ptstr 代替 pstr 和pwstr
将文本串视为字符数组,
将通用数据类型(TCHAR和PTSTR)用于文本字符和字符串
将显示数据类型用BYTE和PBYTE,用于字节和字节指针和数据缓存
将text定义源字符串
想获得一个缓存的大小,用(sizeof(buff))/(sizeof(tchar))
若要分配字符数组的大小(n),malloc(n*sizeof(tchar))
LCID GetThreadLocale(VOID) 可以获取当前使用的那种语言
资源字符串的值总是写作unicode
MultiByteToWideChar 是将单字节转换城多字节
WideCharToMultiByte将unicode转换成ansi
在定义dll时,可以定义两种函数
BOOL strResW(pwstr);
BOOL strResC(pstr);
#ifdef unicode
#define stringRes strResW
#else
#define stringRes strResA
#endif
这样既有unicode也有ansi