对于如下程序,用VC 6.0在XP和VS 2019在Windows 10下测试。
#include <stdio.h>
#include <windows.h>
int main(int argc, char* argv[])
{
wchar_t *pc;
char MultiStr[] = "ABC中文";
wchar_t DBStr[] = L"ABC中文";
char NewBuf[128];
int PrintCount;
printf("%s\n", MultiStr);
pc = DBStr;
while(*pc) {
printf("%04x ", (unsigned int)*pc);
pc++;
}
printf("\n");
if(0 == WideCharToMultiByte(CP_ACP, 0, DBStr, 6, NewBuf, sizeof NewBuf, NULL, NULL)) {
printf("WideCharToMultiByte Error:%d\n", GetLastError());
}
else {
printf("WideCharToMultiByte:%s\n", NewBuf);
}
PrintCount = wprintf(L"%s\n", DBStr);
printf("PrintCount:%d\n", PrintCount);
return 0;
}
在XP下测试结果:

最后的“ABC中文”的中文显示不出来,而且wprintf显示是出错的。
在VS 2019在Windows 10下测试:

虽然wprintf输出没有报错(6个字符),但“中文”两个字符没有正确输出。
究其原因,是因为Windows的命令提示符在简体中文操作系统上的缺省代码页是936,即中文GBK编码。而上述代码中的L"ABC中文"是UTF-16编码,所以通过WideCharToMultiByte转换成多字节编码之后能正常显示。
那么Windows 命令提示符支持UTF-16编码吗?答案是不能。网上查UTF-16编码的代码页是1200,但在命令提示符下输入:chcp 1200,显示“无效代码页”!
本文探讨了Windows环境下不同编码之间的转换问题,特别是在命令提示符中显示UTF-16编码字符串遇到的问题。文章通过一个示例程序展示了在不同版本的Windows和编译器下,如何使用WideCharToMultiByte函数进行编码转换,并解释了为何某些字符无法正确显示。

7488





