您的位置:首页 > 其它

编码转换

2016-06-15 09:51 267 查看
我们在linux系统下的man
page的第三节还可以看到一组iconv函数它们分别是:

1)iconv_open函数用于初始化用于转换的内部缓冲区,指明需要从何种编码方式转换到哪一种。

iconv_t iconv_open(const char *tocode,const char *fromcode);

2)iconv函数进行实际的转换,需要给出两个间接缓冲区指针和剩余字节数指针。该函数需要更新所有相关信息,因此将不可改写的指针传递给iconv是错误的。

size_t iconv(iconv_t cd,char **inbuf,size_t *inbytesleft,char **outbuf,size_t *outbytesleft);

3)iconv_close函数释放iconv_open函数的缓冲区。

int iconv_close(iconv_t cd);

4)iconv_open函数用来打开一个编码转换的流,iconv函数的作用是实际进行转换,iconv_close函数的作用就是关闭这个流。实际用法参见下面的例子,下面是一个将UTF-8码转换成GBK码的例子,我们假设已经有了一个uft8编码的输入缓冲区inbuf以及这个缓冲区的长度inlen。

iconv_tcd=iconv_open("GBK","UTF-8");

char*outbuf=(char*)malloc(inlen*4);

bzero(outbuf,inlen*4);

char*in=inbuf;

char*out=outbuf;

size_toutlen=inlen*4;

iconv(cd,&in,(size_t*)&inlen,&out,&outlen);

outlen=strlen(outbuf);

printf("%s\n",outbuf);

free(outbuf);

iconv_close(cd);

非常值得注意的地方是:iconv函数会修改参数in和参数out指针所指向的地方,也就是说,在调用iconv函数之前,我们的in和inbuf指针以及out和outbuf指针指向的是同一块内存区域,但是调用之后out指针所指向的地方就不是outbuf了,同理in指针。所以要

char*in=inbuf;char*out=outbuf;

另存一下,使用或者释放内存的时候也要使用原先的那个指针outbuf和inbuf。
注:拷贝百度百科
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签:  编码转换