五分钟带你了解ABI

yeyeyeyeyeye~~~
前段时间碰到个问题,用了某个三方库,有so文件的,但只有armeabi文件夹,而我的手机是ARMv7的,而且项目有在armeabi-v7a文件夹下也有so文件,最后就导致了报错。有点绕啊,总之就是在用到了so文件和armeabi、armeabi-v7a、arm64-v8a、x86、x86_64、mips、mips64这些文件夹的地方报错了。

一. ABI

那么就有需要简单的了解下ABI,什么是ABI,ABI全称Application binary interface(应用程序二进制接口),在官网这里(https://developer.android.com/ndk/guides/abis.html?hl=zh-cn)有介绍,good,我喜欢中文文档,上面有说
不同的 Android 手机使用不同的 CPU,而不同的 CPU 支持不同的指令集。CPU 与指令集的每种组合都有专属的应用二进制接口,即 ABI。ABI 可以非常精确地定义应用的机器代码在运行时如何与系统交互。您必须为应用要使用的每个 CPU 架构指定 ABI。
意思大概说的是我碰到的问题是关于CPU架构的问题,不同的手机还会用到不同的armeabi这些文件夹。

二. ABI种类

1. 目前的ABI类型有armeabi、armeabi-v7a、arm64-v8a、x86、x86_64、mips、mips64
2. 目前用到的CPU架构有ARMv8、ARMv7、ARMv5、x86_64、x86、MIPS64、MIPS

(1)ARMv5:第五代的ARM处理器,早期的手机用得比较多,现在已经很少了
(2)ARMv7:第七代的ARM处理器,目前用得比较多
(3)arm64-v8a:第八代64位,在 MIPS64 架构上进行改进(硬件这块我不是很懂)
(4)x86、x86_64:基本用于平板,intel 系统
(5)mips、mips64:用得更加少,索尼好像有用到(我也不是很清楚)

三. ABI与CPU

大概了解之后,我们要做的事情就是要把鸡蛋(so文件)放到正确的篮子里。哪种CPU架构的机器会优先加载哪个目录下的so文件。
我在网上找了一张图,写得很好https://www.jianshu.com/p/170f65439844

五分钟带你了解ABI_第1张图片

意思是假如你的手机是ARMv7的,比如我这里有台华为ARMv7的,如果你在jniLibs只有个目录是x86的,那就可能会报错,因为我手机不会去加载这个目录的文件,它只支持armeabi和armeabi-v7a。
如果有armeabi和armeabi-v7a两个目录,假设armeabi中有a.so和b.so,armeabi-v7a中只有b.so。那会根据图中的优先级加载armeabi-v7a文件夹,调用b.so的地方就不会报错,调用a.so的地方会报错,因为armeabi-v7a没有这个文件,而如果没有armeabi-v7a这个目录,它就会去找优先级较低的armeabi目录,虽然不会报错,但是性能会有些损耗。

现在市场上大部分都是ARMv7的,所以有些大厂只支持armeabi和armeabi-v7a,甚至有些只支持armeabi-v7a,但是从上面看,mips、mips64可以忽略,只要适配armeabi和armeabi-v7a就能适配所有机型

你可能感兴趣的:(Android)