问题描述
Android 使用多个包含 .so 的第三方库,应用崩溃。日志显示找不到 xxx.so
。
问题分析
现在很多第三方库都是通过aar方式引用的,里面也包含了 .so 库。这些so会被编译进apk的lib文件夹下。apk解压后可能类似下面:
手机在使用这些so时,会先根据自身的CPU加载自己优先支持的架构的库,如果发现架构对应的文件夹存在,则会将该文件夹下的 so 推入 apk 安装目录的lib文件夹下。例如:armeabi-v7a 的手机优先支持 armeabi-v7a,如果armeabi-v7a不存在,则会加载 armeabi 。如果在armeabi-v7a文件夹存在,但是 so 库不全,就会报错。
问题解决
遇到这种情况,可以优先尝试补全对应的 .so ,如果行不通,就需要移除 apk 中的 armeabi-v7a 文件夹,让手机加载 armeabi 的库。
通过 aar 方式依赖的库,很多 .so 库会直接包含在 aar包内,我们无法更改他们,但是可以通过 gradle 设置最终输出到 apk 的的 so。
在 app 的 build.gradle 中指定位置添加如下代码:
android {
//省略...
defaultConfig{
ndk{
//输出armeabi的so
abiFilters "armeabi"
}
}
//省略...
}
设置完后,重新编译下 apk,可以看到 apk/lib
中只包含 armeabi
了。