1. 需求
如果你在系统中涉及到字符编码集的时候,比如网页端一般使用字符编码是 utf-8,迪文屏一般支持的字符编码是 GB2312...对于字符编码间的转换在一些时候是一个绕不过的坎。那此篇文章对你可能有所有帮助。
如果你的程序在ubuntu中,在程序中包括 #include ,使用iconv集就能正常实现字符编码的转换,但如果是在arm板中,简单的包含头文件,iconv函数集是不能运行的,需要我们单独的移植 libiconv 库。
2. 正文
(1)交叉编译libiconv库
①下载:我们先从官网下载libiconv库源码文件, 我此次选择的版本是 libiconv-1.10.tar.gz
②解压
③编译前配置
> ./configure --prefix="你自己想要存放编译出来的文件夹" --host=arm-linux --CC=“交叉编译工具同交叉编译选项/设置全部变量情况下,此CC省略”
④编译和整理到指定的文件中
> make
> make install
(2)使用方法
有两种方法:
①配置系统文件,支持libiconv库
在 /etc/profile 文件中添加
export LD_PRELOAD="preloadable_libiconv.so文件存放的位置"
相应的对应上边的操作,我们需要把编译出来的文件中找到此文件,放到相应位置上。
此方法在开机启动的程序中使用,不能保证每次重启后都能加载成功的现象,因此,此方法暂时抛弃。
②使用动态库
将生成的库文件中的 libiconv.so、libiconv.so.2、libiconv.so.2.3.0 拷贝到arm板的根文件系统的库文件夹下,如果cp的话要加 -a 选项,保留软连接特性。
在要使用的程序中,我们将 iconv.h 头文件添加到工程中,Makefile中添加 -liconv 链接选项,在使用到iconv函数集的文件中包含进头文件 #include "iconv.h" 。即可。
特殊说明,如果不包含iconv.h文件,是不成功的。不能使用 #include
3. iconv函数集使用例子
/*
* 将UTF8转到GB2312,遇到不能转的,找到邻近的继续转换
* 转换后,结果放到s_outbuffer中,其中存放的字符的长度是函数的返回值
*/
int ConvertUTF8ToASCII( const char* inbuffer, char *s_outbuffer )
{
const char* srcStart = inbuffer;
char* tempOutBuffer = s_outbuffer;
size_t srcLen = strlen(inbuffer);
size_t outLen = 218;
if (srcLen == 0) return 0;
iconv_t cd = iconv_open("GB2312//TRANSLIT", "UTF-8"); // UTF8 -> GB2312
if (cd == (iconv_t)(-1)) {
perror("iconv_open is error");
}
int ret = iconv(cd, (char **)&srcStart, &srcLen, &tempOutBuffer, &outLen);
if (ret < 0) {
printf("ret is %d
", ret);
perror("iconv");
}
iconv_close(cd);
return 218-outLen;
}
注意函数中 outLen = 218 参数,根据你要转的buf的容限来更改,并相应的更改return中的218的值。