UTF8 & GBK之间的转换
2024-08-24 04:33:48
使用lua的时候,在lua中给字符串赋值的中文,但是在C中读出来的就是乱码,是因为在lua中使用的是UTF8编码,而在C(windows下面)中使用的是GBK编码,将UTF8转成GBK就可以了,下面的代码就是实现这一转换的
转自:http://www.cppblog.com/zgysx/articles/13085.html
// 1、将GBK转换成UTF8 string GBKToUTF8(const std::string& strGBK)
{
string strOutUTF8 = "";
WCHAR * str1;
int n = MultiByteToWideChar(CP_ACP, , strGBK.c_str(), -, NULL, );
str1 = new WCHAR[n];
MultiByteToWideChar(CP_ACP, , strGBK.c_str(), -, str1, n);
n = WideCharToMultiByte(CP_UTF8, , str1, -, NULL, , NULL, NULL);
char * str2 = new char[n];
WideCharToMultiByte(CP_UTF8, , str1, -, str2, n, NULL, NULL);
strOutUTF8 = str2;
delete[]str1;
str1 = NULL;
delete[]str2;
str2 = NULL;
return strOutUTF8;
} // 2、将UTF8转换成GBK string UTF8ToGBK(const std::string& strUTF8)
{
int len = MultiByteToWideChar(CP_UTF8, , strUTF8.c_str(), -, NULL, );
unsigned short * wszGBK = new unsigned short[len + ];
memset(wszGBK, , len * + );
MultiByteToWideChar(CP_UTF8, , (LPCTSTR)strUTF8.c_str(), -, wszGBK, len); len = WideCharToMultiByte(CP_ACP, , wszGBK, -, NULL, , NULL, NULL);
char *szGBK = new char[len + ];
memset(szGBK, , len + );
WideCharToMultiByte(CP_ACP,, wszGBK, -, szGBK, len, NULL, NULL);
//strUTF8 = szGBK;
std::string strTemp(szGBK);
delete[]szGBK;
delete[]wszGBK;
return strTemp;
}
最新文章
- ImageLoader
- winform右下角弹窗
- Android 时间格式的正则表达式
- 【转】Linux高级字符设备之Poll操作
- CentOS7 network
- JMS之开源实现ActiveMQ
- VMWare中安装CentOS6.6不能上网的解决办法
- C 中随机数
- COJ 0503 比赛
- 输出宽字符数组 C++
- 用JavaScript将数字转换为大写金额
- python parse命令行参数
- SQL 无限级分类语句
- 转:Validation of viewstate MAC failed异常的原因及解决方法
- JS自定义对象,正则表达式,JQuery中的一些知识点
- python scapy的用法之ARP主机扫描和ARP欺骗
- 用nodejs搭建一个简单的服务监听程序
- Json2:使用gson解析为List和Map
- mysql 获取自增主键
- 使用 CasperJS 构建 Web 爬虫