iconv库的移植

2019-07-12 19:16发布

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的值。