让apk只包含指定的so
来源:互联网 发布:淘宝推广链接 编辑:程序博客网 时间:2024/05/15 01:48
问题描述
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
了。
阅读全文
0 0
- 让apk只包含指定的so
- 让APK只包含指定的ABI
- 让APK只包含指定的ABI
- 让APK只包含指定的ABI
- 让APK只包含指定平台的so库(abi)
- Android源码中内置包含so文件的APK文件
- Android源码中内置包含so文件的APK文件
- 只让指定的机器连接SQLServer服务器
- 只让指定的机器连接SQLServer服务器
- 只让指定的机器连接SQLServer服务器
- 只让指定的机器连接SQLServer服务器
- 只让指定的机器连接SQLServer服务器
- 只让指定的机器连接SQLServer服务器
- 只让指定的机器连接SQLServer服务器
- 只让指定的机器连接SQLServer服务器
- 只让指定的机器连接SQLServer服务器
- 只让指定的机器连接SQLServer服务器
- 只让指定的机器连接SQLServer服务器
- Java 7之基础
- 笔记三 控件使用
- Python3中urllib的一点坑
- 【脚本语言系列】关于Python系统管理,你需要知道的事
- hibernate的currentSession和多线程问题
- 让apk只包含指定的so
- 高级事件
- android开发之&查看SHA1值
- 国际贸易基础(五)报价
- 深入理解 Java 虚拟机--线程安全与锁优化
- cents7+tomcat
- sqlserver2008压缩数据库主文件语句
- test
- Oracle的update语句研究