早期Android系统几乎只支持ARMv5的CPU架构,现在发展为了七种:ARMv5,ARMv7 (从2010年起),x86 (从2011年起),MIPS (从2012年起),ARMv8,MIPS64和x86_64 (从2014年起),每一种CPU架构都关联一种ABI。
ABI即Application Binary Interface,定义了二进制接口(比如so文件)交互规则,以适用于不同CPU。
Android ABI:
Android目前支持以下七种ABI:armeabi、armeabi-v7a、arm64-v8a、x86、x86_64、mips、mips64。主流的ABI包括:
- armeabiv-v7a: 第7代及以上的 ARM 处理器。
- arm64-v8a: 第8代、64位ARM处理器。
- armeabi: 第5代、第6代的ARM处理器,早期的手机用的比较多。
- x86: 平板、模拟器用得比较多。
- x86_64: 64位的平板。
mips和mips64很少用,以下不予描述。
NDK支持的ABI
NDK是啥?当你的Android工程中用到 C/C++ 代码时就会使用 NDK 这个开发工具包进行开发。
NDK即Native Development Kit,属于Android,与Java无直接联系,是一组可以让您在Android应用中快速开发 C/C++ 的动态库,并自动将 so 和应用一起打包成 apk。NDK是Android中实现JNI的手段,JNI即Java Native Inteface使得Java与本地其他类型语言(如C/C++)进行交互。
NDK以前支持mips,mips64,armeabi,但在NDK r17 移除了对这些ABI的支持。
因为NDK向前兼容(前,forward,未来),推荐使用app的minsdkVersion对应的编译平台,而不是最新。
ABI与CPU
大多数CPU都支持多种ABI,但是为了获得最佳性能,最好使用CPU的主要ABI。如同时存在多个ABI(比如so文件),会安装最优ABI,其他的不会安装。
64位设备(arm64-v8a, x86_64, mips64)能够运行32位的so库。但是以32位模式运行时,会丢失专为64位优化过的性能特征(ART, WebView, Media, etc.)。
references:
- https://www.cnblogs.com/liushilin/p/6292263.html
- https://www.jianshu.com/p/b17f9b926f2b
- https://www.jianshu.com/p/170f65439844