本文主要是介绍iconv用法,编码转换(一),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
iconv用法,编码转换 (一)
2010-11-24 17:18:58| 分类:linux | 标签:|字号大中小订阅
iconv_t iconv_open(const char *tocode, const char *fromcode); size_t iconv(iconv_t cd, char **inbuf, size_t *inbytesleft, char **outbuf, size_t *outbytesleft); int iconv_close(iconv_t cd); iconv_open函数用来打开一个编码转换的流,iconv函数的作用是实际进行转换,iconv_close函数的作用就是关闭这个流。实际用法参见下面的例子,下面是一个将UTF-8码转换成GBK码的例子,我们假设已经有了一个uft8编码的输入缓冲区inbuf以及这个缓冲区的长度inlen。 iconv_t cd = iconv_open( "GBK", "UTF-8"); char *outbuf = (char *)malloc(inlen * 4 ); bzero( outbiuf, inlen * 4); char *in = inbuf; char *out = outbuf; size_t outlen = 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。
附DEMO:
#include<iconv.h>
#include<iostream>
#include<fstream>
using namespace std;
int main()
{
iconv_t cd = iconv_open("GBK","UTF-8");
if(cd == (iconv_t)(-1))
{
cout<<"Failed";
}
else
{
cout<<"Success"<<endl;
}
ifstream fp("1.html"); //1.html为utf8格式文件
char * inbuf = new char[1000] ;
string s;
while(getline(fp,s))
{
inbuf = (char *)s.c_str();
char * in = inbuf;
char * outbuf = new char[1000];
char * out = outbuf;
size_t inlen = 1000;
size_t outlen = 1000;
iconv(cd,&in,&inlen,&out,&outlen);
cout<<outbuf;
}
iconv_close(cd);
return 0;
}
这篇关于iconv用法,编码转换(一)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!