Android强行进阶:为何大厂APP如微信、支付宝、淘宝、手Q等只适配了armeabi-v7a-armeabi?,看这一篇就够了

本文探讨了Android应用程序如何针对不同CPU架构进行适配,尤其是大厂如微信、支付宝、淘宝和手机QQ的适配策略。主要关注armeabi-v7a和armeabi平台。内容包括ABI工作原理、主辅助ABI的适配流程,以及如何通过配置abiFilters减少APK大小。同时,文章分析了各CPU架构的市场占有率,建议在性能和兼容性之间做出权衡,例如只适配armeabi-v7a。此外,介绍了Google的abi split技术,允许为每个CPU架构创建单独的APK,以实现性能和兼容性的兼顾,但指出国内应用商店尚未支持此功能。
摘要由CSDN通过智能技术生成

// 适配指定CPU架构
ndk {
abiFilters ‘arm64-v8a’, ‘x86_64’
}
}
}

效果如下:

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

可以看到,只生成了我们指定CPU架构的so文件,包的大小也减少了5.3MB

这时候,你可能会有一个疑问,Android 共支持7种CPU架构,那么,我们在实际项目中该适配哪些CPU架构能保证最好的兼容,同时又最大限度的减少APK的大小?

在回答这个问题之前,我们不妨看一下这些顶级巨头公司,他们是是如何适配的。

3. 目前大厂APP是如何适配不同的CPU架构的?

首先,我们下载一些大厂的APK,看一下他们的适配情况,这里我分析了微信、手机QQ、支付宝和淘宝这4个APP的适配情况:

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

可以看到,微信适配的是arm64-v8a(微信应该是最近才适配到arm64-v8a,以前是armeabi),支付宝和手Q适配的是armwabi,淘宝适配的是armwabi-v7a。各个APP适配的平台不太一样,但是他们有一个共同点,那就是它们只指定了一个平台。

等等,上面这些APP只适配了一中CPU架构,比如只适配了armwabi-v7a,那如果APP装在其他架构的手机上,如arm64-v8a上,会蹦吗?

要弄清楚这个问题,我们得先搞清楚,ABI是如何工作的。

ABI是如何工作的呢?

官方文档解释如下:

Android 系统在运行时知道它支持哪些 ABI,因为版本特定的系统属性会指示:

  • 设备的主要 ABI,与系统映像本身使用的机器代码对应。
  • (可选)与系统映像也支持的其他 ABI 对应的辅助 ABI。

此机制确保系统在安装时从软件包提取最佳机器代码。

为实现最佳性能,应直接针对主要 ABI 进行编译。例如,基于 ARMv5TE 的典型设备只会定义主 ABI:armeabi。相反,基于 ARMv7 的典型设备将主 ABI 定义为 armeabi-v7a,并将辅助 ABI 定义为 armeabi,因为它可以运行为每个 ABI 生成的应用原生二进制文件。

64 位设备也支持其 32 位变体。以 arm64-v8a 设备为例,该设备也可以运行 armeabi 和 armeabi-v7a 代码。但请注意,如果应用以 arm64-v8a 为目标,而非依赖于运行 armeabi-v7a 版应用的设备,则应用在 64 位设备上的性能要好得多。

许多基于 x86 的设备也可运行 armeabi-v7a 和 armeabi NDK 二进制文件。对于这些设备,主 ABI 将是 x86,辅助 ABI 是 armeabi-v7a。

上面这一段是不是有点看蒙了,这里我来简单解释以下。

  • 19
    点赞
  • 28
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值