zl程序教程

您现在的位置是:首页 >  移动开发

当前栏目

编译可在Android上运行的依赖库(三):libffi库

Android依赖 运行 编译
2023-09-14 09:04:38 时间

本文在Ubuntu 64位系统上对libffi项目进行交叉编译。

下文中的"NDK"若无特殊说明均指"Android NDK"。


1. 下载并安装Android NDK

下载并安装Android NDK的过程在这里不做介绍。

2. 下载libffi

到libffi的官网去下载这个库的源码。官网地址:https://sourceware.org/libffi/

3. 设置NDK和SYSROOT环境变量

请参考编译可在Android上运行的glib库中相应的步骤。

注意:这里没有也不需要“创建NDK工具的软链接”这个步骤。

4. 运行configure

CPP="arm-linux-eabi-gcc -E" CXXCPP="arm-linux-eabi-gcc -E" CPPFLAGS="-I${SYSROOT}/usr/include" ./configure --prefix="${SYSROOT}/usr" --host=arm-linux-androideabi CFLAGS="--sysroot $SYSROOT"

对./configure命令的解析请参考编译可在Android上运行的libiconv库中的相应步骤。

5. 编译和安装

使用make命令编译源码,当编译成功是使用"make install"命令进行安装,libiconv将会被安装到${SYSROOT}/usr/lib目录下,在上文中"--prefix="${SYSROOT}/usr"命令选项就是用来指定安装的目录的。

注意:libffi库安装后的库文件被安装到"${SYSROOT}/usr/lib"目录下,头文件被安装到"${SYSROOT}/usr/lib/libffi-3.2.1/include"目录下,将"${SYSROOT}/usr/lib/libffi-3.2.1/include"目录下的头文件拷贝到"${SYSROOT}/usr/include"目录下。


作者:寻禹@阿里聚安全,更多技术文章,请点击阿里聚安全博客


阿里聚安全由阿里巴巴移动安全部出品,面向企业和开发者提供企业安全解决方案,全面覆盖移动安全、数据风控、内容安全、实人认证等维度,并在业界率先提出“以业务为中心的安全”,赋能生态,与行业共享阿里巴巴集团多年沉淀的专业安全能力。


聚安全平台 阿里聚安全是一个移动安全开放平台,凝聚阿里巴巴多年来在无线业务安全防御的成功经验和技术成果,并面向开发者和企业提供恶意代码检测、漏洞扫描、仿冒应用检测、应用加固、安全组件等服务,一站式解决应用的安全问题。