UTF-8到acsii的转换(让自己的C++程序支持多语言)

类别:编程语言 点击:0 评论:0 推荐:

我的思路是这样的:在配置文件(基本上使用XML格式)中采用UTF-8编码,这样世界上的任何文字就都可以显示了。但是如果直接将配置内容读出并显示,在你的C++程序里面肯定是乱码,那么怎么解决呢?步骤如下(直接看代码吧)

char szUTF8 [] = {0xE4,0XBB,0XB7,0XE5,0X80,0XBC};//是汉语的价值两个字

int nLen = MultiByteToWideChar( CP_UTF8, 0, szUTF8, -1, NULL, NULL );//得到UTF8编码的字符串长度,是2

LPWSTR lpwsz = new WCHAR[nLen];

MultiByteToWideChar( CP_UTF8, 0, szUTF8, -1, lpwsz, nLen );//转换的结果是UCS2格式的价值两个字

int nLen1 = WideCharToMultiByte( CP_ACP, 0, lpwsz, nLen, NULL, NULL, NULL, NULL );

LPSTR lpsz = new CHAR[nLen1];

WideCharToMultiByte( CP_ACP, 0, lpwsz, nLen, lpsz, nLen1, NULL, NULL );//转换完毕,得到了在我的机器上的"价值"两个字的二进制编码0xbc 0xdb 0xd6 0xb5

delete [] lpwsz; delete [] lpsz;

随后,我测试了俄语、西班牙语、日语、繁体中文等都能够正常显示。

但是好像有一些怪字符不能显示,不知道这些字符是什么语言的字符集。
通过对以上知识的了解,应该很容易在C++程序中加入多语言支持了吧。

本文地址:http://com.8s8s.com/it/it25632.htm