解决办法:
tmpbuf=tmpbuff; 转码前,标记转码内容首地址
linux下c语言利用iconv函数实现utf-8转unicode,iconv是linux下的编码转换的工具,它提供命令行的使用和函数接口支持。
iconv函数族的头文件是iconv.h,使用前需包含
#include <iconv.h>
iconv函数族有三个函数,原型如下:
函数1:
iconv_t iconv_open(const char *tocode, const char *fromcode);
此函数说明将要进行哪两种编码的转换,tocode是目标编码,fromcode是原编码,该函数返回一个转换句柄,供以下两个函数使用。
函数2:
size_t iconv(iconv_t cd,char **inbuf,size_t *inbytesleft,char **outbuf,size_t *outbytesleft);
此函数从inbuf中读取字符,转换后输出到outbuf中,inbytesleft用以记录还未转换的字符数,outbytesleft用以记录输出缓冲的剩余空间。
注意:inbuf和outbuf都必须是有存储空间的不能定义为常量,如:char *inbuf = "abc" 或者是char *outbuf = "123"这样定义都是错误的。可以malloc申请空间,或者char outbuff[64]=“”。(另外inbuf,inbytesleft,outbuf,outbytesleft这几个参数在使用过程中都会改变,最好是先保存一下原值,然后再使用。)
要想知道转换编码后的string的首地址,需要先保存编码转换前string的首地址,tmpbuf=tmpbuff; 使用过程tmpbuff首地址会丢失;
需要知道转换后的编码长度值outbytesleft,outbytesleft=maxlen-outbytesleft;这里maxlen=2*strlen(inbuf);inbuf转码前。
函数3:
int iconv_close(iconv_t cd);
此函数用于关闭转换句柄,释放资源。
网友评论