问题描述
最近接触安卓开发,用Android studio运行一个程序时出现这样的问题:APP启动时跳出弹框:Detectedproblems with appnative libraries (please consult log for detail) : libxxx.so: text relocations.
项目中minSdkVersion 15、targetSdkVersion 22、compileSdkVersion 26
经分析发现当targetSdkVersion<23且使用debug签名,运行在6.0+的Android设备上,每次启动时就会跳出这样一个弹窗。引起该问题的最根本原因,是so动态链接库的代码并非PIC。解决方法就是解决so动态链接库中的text relocations 问题。
解决方案
在网上进行搜索,解决方案大致有这么两种:修复源码中的text relocations和编译时处理。修复源码中的text relocations比较麻烦,而且没有so动态库的源码,定位到了也无法修改。这里选择第二种方法来对问题进行处理,使用NDK编译so时配Android.mk,增添PIC相关的配置项,这样编译出来的so文件将不再有text relocations的问题。
首先需要我们配置NDK,Android studio中可以直接下载NDK,整个操作可以分为以下几步:
- android studio中下载NDK、CMake(SDK Manager)
- Project Structure ->SDK Location 选择NDK路径
- Local.properties中引入NDK路径
- 配置NDK系统环境变量(加入Path中)
配置Android.mk,在文件中加入
LOCAL_LDFLAGS += -fPIC
PIC参数用于编译位置无关代码,生成可用于共享库的位置独立代码。若不添加-fPIC,则加载so文件的代码段时,代码段引用的数据对象需要重定位,重定位会修改代码段内容,这样就导致没使用这个so文件,代码段的进程在内核中就会生成这个文件的拷贝。
在build.gradle(app)中添加NDK模块
defaultConfig {
// ndk {
// moduleName "libserial_port" //设置库(so)文件名称
// ldLibs "log"//实现__android_log_print
// //
// sourceSets.main {
// jni.srcDirs = []
// jniLibs.srcDir 'src/main/libs'
// }
// abiFilters 'armeabi-v7a', 'x86'
// }
// }
// externalNativeBuild {
// ndkBuild {
// path 'src/main/jni/Android.mk' //这个是Android.mk文件的路径
// }
完成后运行,发现又出现这样一个错误:
Gradle sync failed: No toolchains found in the NDK toolchains folder for ABI with prefix: mips64el-linux-android
这个问题好解决,方案有两个:
- 在toolchains下执行命令:mklink /j mips64el-linux-android aarch64-linux
-android-4.9 - 官网重新下载NDK,找到缺少的文件进行复制
简单记录下,以防时隔数载后的遗忘
|