wchar_t是Unicode字符的数据类型,它实际定义在<string.h>里: typedef unsigned short wchar_t; 下面在看看TCHAR。如果你希望同时为ANSI和Unicode编译的源代码,那就要include TChar.h。TCHAR是定义在其中的一个宏,它视你是否定义了_UNICODE宏而定义成char或者wchar_t。如果你使用了TCHAR,那 么就不应该使用ANSI的str...
char叫多字节字符,一个char占1个字节,之所以叫多字节字符是因为它表示一个英文字符时是一个字节,而中文字符时是多个字节。 wchar_t被称为宽字符,一个wchar_t占2个字节。之所以叫宽字符是因为所有的字都要赋值时,前面要加L,如:wchar_t str[3]=L”中国”;。 注意:两种字符对应的字符串函数也不一样,strlen(...
typedef wchar_t TCHAR; #else typedef unsigned char TCHAR; #endif 然后发现了问题就是出在编码方式上,两个程序一个使用的UNICODE编码,而另一个不是,所以才导致了同样的代码,一个能正确执行,另一个却不行的情况。