sqlite在安卓下使用ndk的交叉编译

对于linux系统,sqlite的交叉编译非常简单。下面分别以32位的arm和64位的arm为例进行介绍。

  1. 32位arm,以hisi3521a为例,首先进行配置:
    ./configure --prefix=/home/crystal/sqlite3/hisv300_install --host=arm-hisiv300-linux
    然后
    make;make install-strip
  2. 64位arm,以hisi3519dv500为例,首先进行配置:
    ./configure --prefix=/home/crystal/sqlite3/hisdv500_install --host=aarch64-v01c01-linux-gnu
    然后
    make;make install-strip
    对于安卓系统使用ndk编译,情况就不一样了,--host=aarch64-linux-android在configure的时候不会被识别,我采用下面的方法来生成,首先运行:
    ./configure --prefix=/home/crystal/sqlite3/android_install --host=aarch64-linux-gnu生成一份arm64位linux下的make file,然后修改这个makefile,将所有的aarch64-linux-gnu替换为aarch64-linux-android。
    另外,在makefile里CFLAGS和BUILD_CFLAGS都加上:-D__ANDROID_API__=27 -pie -fPIE --Wall。最后编译过程中找不到libdl.so,修改makefile的LDFLAGS = -L/home/crystal/all-android-toolchain/arm64/aarch64-linux-android/27/sysroot/usr/lib指定动态库路径。编译前记得export PATH=/home/crystal/all-android-toolchain/arm64/aarch64-linux-android/27/bin:$PATH。至此,就可以make;make install-strip了。
相关推荐
逐光老顽童8 分钟前
Java 与 Kotlin 混合开发避坑指南:30 个真实案例实录
android·kotlin
冬奇Lab12 小时前
每日一个开源项目(第134篇):Zvec - 阿里开源的嵌入式向量数据库,向量搜索界的 SQLite
数据库·人工智能·llm
爱勇宝12 小时前
鸿蒙生态的下半场:开发者不只要能开发,还要能赚钱
android·前端·程序员
Yeyu16 小时前
刷新一帧的艺术:invalidate / postInvalidate / postInvalidateOnAnimation全解析
android
潘潘潘17 小时前
Android OTA 升级原理和流程介绍
android
ClouGence1 天前
Oracle CDC 架构优化:从主库直连到 DataGuard 备库同步
数据库·后端·oracle
plainGeekDev1 天前
null 判断 → Kotlin 可空类型
android·java·kotlin
plainGeekDev1 天前
getter/setter → Kotlin 属性
android·java·kotlin
YXL1111YXL1 天前
Handler 消息回收与协程异步执行的时序陷阱
android
无响应de神1 天前
三、用户与权限管理
数据库·mysql