tinyxml读取中文时显示乱码的解决方法
2016-12-10 14:20
801 查看
tinyxml解析器是一个很好用的,乱码是由于GB2312与UTF8之间转换不当造成的,tinyxml在处理UTF8本身没有问题。
这里是网上找的一个经测试可以用的转换方法: printf("%s", U("中文汉字")); 即可
代码如下:
载自: http://blog.csdn.net/xiaoxiaoyusheng2012/article/details/45315955
这里是网上找的一个经测试可以用的转换方法: printf("%s", U("中文汉字")); 即可
代码如下:
#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 };
载自: http://blog.csdn.net/xiaoxiaoyusheng2012/article/details/45315955
相关文章推荐
- tinyxml读取中文时显示乱码的解决方法
- Python实现的json文件读取及中文乱码显示问题解决方法
- php 读取xml的方法 (iconv解决中文乱码问题)
- Ubuntu下pdf、gedit、vim 中文无法读取或者显示乱码的解决方法
- php读取xml中文乱码解决方法
- Microsoft Visual Studio 2005打开ISV.config或SiteMap.xml中文显示乱码解决方法
- Web网站中从Sybase数据库读取的中文显示为乱码的解决方法
- 解决JAVA,properties loadFromXML读取中文XML乱码的方法
- Python3 configparser读取含有中文配置config.ini(Windows)显示乱码的解决方法
- python 读取mssql server 2005 显示中文总是乱码的解决方法
- Ubuntu下pdf、gedit、vim 中文无法读取或者显示乱码的解决方法
- AS 读取XML,中文显示为乱码的解决办法
- flash+ashx(aspx)读取xml中文乱码解决方法
- flash+ashx读取xml中文乱码解决方法
- C#中StreamReader读取中文文本出现乱码的解决方法
- 饼图显示百分比、图片上热点链接中文乱码的解决方法、 混合图表(不同类型的图混合显示)、
- Ubuntu/Debian下JAVA 中文/图片中文字体乱码显示问题解决方法
- 关于解决StreamReader读取中文乱码的解决方法
- Flex读取外部XML中文乱码解决办法
- SVN+Apache在windows下http访问 显示中文乱码问题的解决方法