linux下UTF-8转GBK编码后,落文件,文件内容丢失,只有几个字符

解决办法:


tmpbuf=tmpbuff; 转码前,标记转码内容首地址


linux下c语言利用iconv函数实现utf-8转unicode,iconv是linux下的编码转换的工具,它提供命令行的使用和函数接口支持。

iconv函数族的头文件是iconv.h,使用前需包含

#include

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);

此函数用于关闭转换句柄,释放资源。

你可能感兴趣的:(linux下UTF-8转GBK编码后,落文件,文件内容丢失,只有几个字符)