tinyxml读取中文时显示乱码的解决方法
2015-04-27 21:32
531 查看
1、tinyxml解析器是一个很好用的,乱码是由于GB2312与UTF8之间转换不当造成的,tinyxml在处理UTF8本身没有问题。
2、网上很多人提供的方法是进行GB2312与UTF8之间的转换
参看:http://blog.sina.com.cn/s/blog_472a9f0c01019eem.html
经测试时有效的
转换代码为:
2、网上很多人提供的方法是进行GB2312与UTF8之间的转换
参看:http://blog.sina.com.cn/s/blog_472a9f0c01019eem.html
经测试时有效的
转换代码为:
#include <Windows.h> #define U (CUtf8String) #define W (CGb2312String) class CUtf8String { public: inline CUtf8String(const char* gb2312) { m_bIsConst = true; #ifdef TEST_TYPE_MAP if (m[gb2312]) { m_utf8 = m[gb2312]; return ; } #endif int buffLen = 0; WCHAR wbuff[5120]; MultiByteToWideChar(CP_ACP, 0, gb2312, -1, wbuff, 5120); buffLen = WideCharToMultiByte(CP_UTF8, 0, wbuff, -1, NULL, 0, 0, 0); m_utf8 = new char[buffLen+1]; WideCharToMultiByte(CP_UTF8, 0, wbuff, -1, (LPSTR)m_utf8, buffLen, 0, 0); #ifdef TEST_TYPE_MAP m[gb2312] = m_utf8; #endif } inline CUtf8String(char* gb2312) { m_bIsConst = false; int buffLen = 0; WCHAR wbuff[5120]; MultiByteToWideChar(CP_ACP, 0, gb2312, -1, wbuff, 5120); buffLen = WideCharToMultiByte(CP_UTF8, 0, wbuff, -1, NULL, 0, 0, 0); m_utf8 = new char[buffLen+1]; WideCharToMultiByte(CP_UTF8, 0, wbuff, -1, (LPSTR)m_utf8, buffLen, 0, 0); } inline ~CUtf8String() { #ifndef TEST_TYPE_MAP if (m_utf8) { delete m_utf8; m_utf8 = 0; } #else if (!m_bIsConst) { if (m_utf8) { delete m_utf8; m_utf8 = 0; } } #endif } inline operator char*() { return (char*)m_utf8; } private: const char* m_utf8; bool m_bIsConst; #ifdef TEST_TYPE_MAP static strmap m; #endif }; class CGb2312String { public: inline CGb2312String(const char* utf8) { #ifdef TEST_TYPE_MAP if (m[utf8]) { m_gb2312 = 0; m_gb2312 = m[utf8]; } #endif int buffLen = 0; WCHAR wbuff[5120]; MultiByteToWideChar(CP_UTF8, 0, utf8, -1, wbuff, 5120); buffLen = WideCharToMultiByte(CP_ACP, 0, wbuff, -1, NULL, 0, 0, 0); m_gb2312 = new char[buffLen+1]; WideCharToMultiByte(CP_ACP, 0, wbuff, -1, (LPSTR)m_gb2312, buffLen, 0, 0); #ifdef TEST_TYPE_MAP m[utf8] = m_gb2312; #endif } inline CGb2312String(char* utf8) { #ifdef TEST_TYPE_MAP if (m[utf8]) { m_gb2312 = 0; m_gb2312 = m[utf8]; } #endif int buffLen = 0; WCHAR wbuff[5120]; MultiByteToWideChar(CP_UTF8, 0, utf8, -1, wbuff, 5120); buffLen = WideCharToMultiByte(CP_ACP, 0, wbuff, -1, NULL, 0, 0, 0); m_gb2312 = new char[buffLen+1]; WideCharToMultiByte(CP_ACP, 0, wbuff, -1, (LPSTR)m_gb2312, buffLen, 0, 0); #ifdef TEST_TYPE_MAP m[utf8] = m_gb2312; #endif } inline ~CGb2312String() { #ifndef TEST_TYPE_MAP if (m_gb2312) { delete m_gb2312; m_gb2312 = 0; } #endif } inline operator char*() { return (char*)m_gb2312; } private: const char* m_gb2312; #ifdef TEST_TYPE_MAP static strmap m; #endif };例子:
printf("%s", U"你好中国!");
相关文章推荐
- tinyxml读取中文时显示乱码的解决方法
- Microsoft Visual Studio 2005打开ISV.config或SiteMap.xml中文显示乱码解决方法
- AS 读取XML,中文显示为乱码的解决办法
- Ubuntu下pdf、gedit、vim 中文无法读取或者显示乱码的解决方法
- flash+ashx(aspx)读取xml中文乱码解决方法
- php 读取xml的方法 (iconv解决中文乱码问题)
- Web网站中从Sybase数据库读取的中文显示为乱码的解决方法
- php读取xml中文乱码解决方法
- flash+ashx读取xml中文乱码解决方法
- Ubuntu下pdf、gedit、vim 中文无法读取或者显示乱码的解决方法
- python 读取mssql server 2005 显示中文总是乱码的解决方法
- 解决JAVA,properties loadFromXML读取中文XML乱码的方法
- Python3 configparser读取含有中文配置config.ini(Windows)显示乱码的解决方法
- Python实现的json文件读取及中文乱码显示问题解决方法
- Python读取.xml文件(<?xml version="1.0" encoding="UTF-16"?>)中文乱码问题解决
- python 写的方法返回的是个中文,在 rf 日志中显示的却是乱码解决方法
- html/jsp中文显示乱码解决方法
- PLSQL Developer 中文显示乱码的解决方法
- QT5.2(不限于5.2)中文显示、输出、读取乱码解决方式
- 关于解决mysql命令窗口无法显示中午结果和显示乱码与显示中文错位的解决方法