为SQLite3提供一个ANSI到UTF8的互转函数
数据库  /  管理员 发布于 5年前   164
在使用Sqlite3时必须要用到的
使用方法:
char* src = "...";//待转换的ANSI或UTF8字符串
char* dst = NULL;//保存由函数内部分配的内存指针, 不需要传入内存缓冲区的
转换为UTF-8:to_utf8(src, &dst);
转换为ANSI:to_gb(src, &dst);
返回值:零 - 失败, 非零 - 成功.
注意:如果操作成功, 需要手动释放函数内部分配的空间:
复制代码 代码如下:
if(dst)
{
free(dst);
dst = NULL;
}
代码:
复制代码 代码如下:
#include <windows.h>
#include <stdio.h>int to_utf8(char* psrc, char** ppdst)
{
int ret,ret2;
wchar_t* pws = NULL;
char* putf = NULL;
ret = MultiByteToWideChar(CP_ACP, 0, psrc, -1, NULL, 0);
if(ret<=0){
*ppdst = NULL;
return 0;
}
pws = (wchar_t*)malloc(ret*2);
if(!pws){
*ppdst = NULL;
return 0;
}
MultiByteToWideChar(CP_ACP, 0, psrc, -1, pws, ret);
ret2 = WideCharToMultiByte(CP_UTF8, 0, pws, -1, NULL, 0, NULL, NULL);
if(ret2<=0){
free(pws);
return 0;
}
putf = (char*)malloc(ret2);
if(!putf){
free(pws);
return 0;
}
if(WideCharToMultiByte(CP_UTF8, 0, pws, ret, putf, ret2, NULL, NULL)){
*ppdst = putf;
free(pws);
return 1;
}else{
free(pws);
free(putf);
*ppdst = NULL;
return 0;
}
}
int to_gb(char* psrc, char** ppdst)
{
int ret, ret2;
wchar_t* pws = NULL;
char* pgb = NULL;
ret = MultiByteToWideChar(CP_UTF8, 0, psrc, -1, NULL, 0);
if(ret<=0){
*ppdst = NULL;
return 0;
}
pws = (wchar_t*)malloc(ret*2);
if(!pws){
*ppdst = NULL;
return 0;
}
MultiByteToWideChar(CP_UTF8, 0, psrc, -1, pws, ret);
ret2 = WideCharToMultiByte(CP_ACP, 0, pws, -1, NULL, 0, NULL, NULL);
if(ret2<=0){
free(pws);
return 0;
}
pgb = (char*)malloc(ret2);
if(!pgb){
free(pws);
*ppdst = NULL;
return 0;
}
if(WideCharToMultiByte(CP_ACP, 0, pws, -1, pgb, ret2, NULL, NULL)){
*ppdst = pgb;
free(pws);
return 1;
}else{*ppdst = 0;
free(pgb);
free(pws);
return 0;
}
}
by: 女孩不哭
122 在
学历:一种延缓就业设计,生活需求下的权衡之选中评论 工作几年后,报名考研了,到现在还没认真学习备考,迷茫中。作为一名北漂互联网打工人..123 在
Clash for Windows作者删库跑路了,github已404中评论 按理说只要你在国内,所有的流量进出都在监控范围内,不管你怎么隐藏也没用,想搞你分..原梓番博客 在
在Laravel框架中使用模型Model分表最简单的方法中评论 好久好久都没看友情链接申请了,今天刚看,已经添加。..博主 在
佛跳墙vpn软件不会用?上不了网?佛跳墙vpn常见问题以及解决办法中评论 @1111老铁这个不行了,可以看看近期评论的其他文章..1111 在
佛跳墙vpn软件不会用?上不了网?佛跳墙vpn常见问题以及解决办法中评论 网站不能打开,博主百忙中能否发个APP下载链接,佛跳墙或极光..
Copyright·© 2019 侯体宗版权所有·
粤ICP备20027696号