文章目录
- 一、前言
- 二、Android的CPU架构
- 三、CPU与ABI的对应关系
- 四、典型的 ABI 包含的信息
- 五、.so文件的命名规范
- 六、.so文件存放位置
一、前言
不同的Android
手机使用不同的CPU
,而不同的 CPU
支持不同的指令集,CPU
与指令集的每种组合都有专属的应用二进制接口,即 ABI(全称:ApplicationBinary Interface)
。
二、Android的CPU架构
Android
系统目前支持以下七种不同的CPU
架构
CPU架构 | 描述 | 时间 |
ARMv5 | 第5代 ARM v5TE,使用软件浮点运算,兼容所有ARM设备,通用性强,速度慢 | |
ARMv7 | 第7代 ARM v7,使用硬件浮点运算,具有高级扩展功能 | 从2010年起 |
x86 | intel 32位,一般用于平板 | 从2011年起 |
x86_64 | intel 64位,一般用于平板 | 从2014年起 |
ARMv8 | 第8代,64位,包含AArch32、AArch64两个执行状态对应32、64bit | 从2014年起 |
MIPS | 少接触 | |
MIPS64 | 少接触 | 从2014年起 |
三、CPU与ABI的对应关系
CPU架构(纵向)\API(横向) | armeabi | armeabi-v7a | arm64-v8a | x86 | x86_64 | mips | mips64 |
ARMv5 | 支持 | ||||||
ARMv7 | 支持 | 支持 | |||||
x86 | 支持 | 支持 | 支持 | ||||
x86_64 | 支持 | 支持 | 支持 | ||||
ARMv8 | 支持 | 支持 | 支持 | ||||
MIPS | 支持 | ||||||
MIPS64 | 支持 | 支持 |
Android
应用支持的ABI
取决于APK
中位于lib/ABI目录
中的.so文件
,其中ABI
可能是上面说过的七种ABI
中的一种。
当一个应用安装在设备上,只有该设备支持的CPU
架构对应的.so
文件会被安装。
选择ABI
时会有个优先级,使用所支持的不同的ABI
会表现出不同的性能。
举个例子x86
设备上,libs/x86目录
中如果存在.so
文件的话,会被安装,如果不存在,则会选择armeabi-v7a
中的.so
文件,如果也不存在,则选择armeabi
目录中的.so
文件。x86
设备能够很好的运行ARM
类型函数库,但并不保证100%
不发生crash
,特别是对旧设备。64位
设备(arm64-v8a, x86_64, mips64
)能够运行32位
的函数库,但是以32位
模式运行,在64位
平台上运行32位
版本的ART
和Android
组件,将丢失专为64位
优化过的性能(ART,webview,media
等等)。
四、典型的 ABI 包含的信息
1 机器代码应使用的 CPU
指令集。
2 运行时内存存储和加载的字节顺序。
3 可执行二进制文件(例如程序和共享库)的格式,以及它们支持的内容类型。
4 用于解析内容与系统之间数据的各种约定。这些约定包括对齐限制,以及系统如何使用堆栈和在调用函数时注册。
5 运行时可用于机器代码的函数符号列表 - 通常来自非常具体的库集。
五、.so文件的命名规范
.so
的名字必须有lib
前缀 否则apk
解压/安装到手机的时候不会把libs\API目录
下的.so
拷贝到/data/data/com.你的应用包名/lib
下。
六、.so文件存放位置
相应的ABI
二进制文件(如.so
文件),要放进相应的ABI目录
中
1 Android Studio工程
放在jniLibs/ABI目录中
(当然也可以通过在build.gradle
文件中的设置jniLibs.srcDir
属性自己指定)
如jniLibs/armeabi/libxxx.so
2 Eclipse工程
放在libs/ABI目录中
(这也是ndk-build
命令默认生成.so
文件的目录)
如libs/armeabi/libxxx.so
3 在AAR压缩包中AAR
压缩包中位于jni/ABI目录中
(.so
文件会自动包含到引用AAR
压缩包的APK
中)
如jni/armeabi/libxxx.so
4 在APK中的路径
最终APK
文件中的lib/ABI目录中
如lib/armeabi/libxxx.so