問(wèn)題描述
項(xiàng)目中需要使用第三方的sdk蒲障,集成完成后在小米4設(shè)備上能夠正常運(yùn)行歹篓,但在三星S6上面運(yùn)行的時(shí)候crash,日志如下:
分析原因:
根據(jù)日志判斷應(yīng)該是so文件未找到揉阎,接著解壓了安裝的apk文件庄撮,發(fā)現(xiàn)在arm64-v8a文件夾下缺失了對(duì)應(yīng)的so文件,小米4采用的處理器為32位處理器毙籽,三星s6采用的是64位處理器重窟,所以s6上運(yùn)行發(fā)生了crash。
解決方案:
1.刪除 arm64-v8a文件夾
- build.gradle文件增加過(guò)濾(推薦使用)
defaultConfig { applicationId "com.swordli.smali" minSdkVersion 14 targetSdkVersion 25 versionCode 1 versionName "1.0" testInstrumentationRunner "android.support.test.runner.AndroidJUnitRunner" ndk { abiFilters "armeabi" } }
問(wèn)題總結(jié):
現(xiàn)在很多第三方的sdk都存在so庫(kù)文件惧财,但是可能由于種種原因沒(méi)有提供所有目錄下的so庫(kù),而有一些sdk卻提供的比較全面如友盟扭仁、百度地圖等垮衷,所以造成在打包生成的apk里面jni的各個(gè)CPU架構(gòu)目錄下不能包含完整的so庫(kù),而導(dǎo)致兼容問(wèn)題乖坠。
如果你的程序有armeabi和arm64-v8a兩個(gè)文件夾搀突,在armeabi里面有l(wèi)ib1.so 和 lib2.so,而在arm64-v8a里面只有l(wèi)ib1.so,那么arm64-v8a的手機(jī)在用到lib2時(shí)就會(huì)找不到導(dǎo)致crash熊泵。由于arm64-v8a是向下兼容的仰迁,所以只需要?jiǎng)h掉arm64-v8a文件夾,讓手機(jī)自適應(yīng)去查找armeabi的so庫(kù)即可顽分。但是這樣并不能完全的做到完美的兼容徐许,因此在使用JNI庫(kù)的時(shí)候最好是拿到對(duì)應(yīng)文件夾的so庫(kù)文件。
arm64-v8a卒蘸、armeabi-v7a雌隅、armeabi、x86介紹:
Android 設(shè)備的CPU類型(通常稱為”ABIs”)
早期的Android系統(tǒng)幾乎只支持ARMv5的CPU架構(gòu)缸沃,現(xiàn)在可以支持七種不同的CPU架構(gòu):ARMv5恰起,ARMv7 (從2010年起),x86 (從2011年起)趾牧,MIPS (從2012年起)检盼,ARMv8,MIPS64和x86_64 (從2014年起)翘单,每一種都關(guān)聯(lián)著一個(gè)相應(yīng)的ABI吨枉。 應(yīng)用程序二進(jìn)制接口定義了二進(jìn)制文件(尤其是.so文件)如何運(yùn)行在相應(yīng)的系統(tǒng)平臺(tái)上蹦渣,從使用的指令集,內(nèi)存對(duì)齊到可用的系統(tǒng)函數(shù)庫(kù)东羹。在Android 系統(tǒng)上剂桥,每一個(gè)CPU架構(gòu)對(duì)應(yīng)一個(gè)ABI:armeabi,armeabi-v7a属提,x86权逗,mips,arm64- v8a冤议,mips64斟薇,x86_64。
各版本分析如下:
mips / mips64: 極少用于手機(jī)可以忽略
x86 / x86_64: x86 架構(gòu)的手機(jī)都會(huì)包含由 Intel 提供的稱為 Houdini 的指令集動(dòng)態(tài)轉(zhuǎn)碼工具恕酸,實(shí)現(xiàn) 對(duì) arm .so 的兼容堪滨,再考慮 x86 1% 以下的市場(chǎng)占有率,x86 相關(guān)的兩個(gè) .so 也是可以忽略的
armeabi: ARM v5 這是相當(dāng)老舊的一個(gè)版本蕊温,缺少對(duì)浮點(diǎn)數(shù)計(jì)算的硬件支持袱箱,在需要大量計(jì)算時(shí)有性能瓶頸
armeabi-v7a: ARM v7 目前主流版本
arm64-v8a: 64位支持
所謂的ARMv8架構(gòu),就是在MIPS64架構(gòu)上增加了ARMv7架構(gòu)中已經(jīng)擁有的的TrustZone技術(shù)义矛、虛擬化技術(shù)及NEON advanced SIMD技術(shù)等特性发笔,研發(fā)成的。
PS:在2011年11月凉翻,ARM公司發(fā)布了新一代處理器64位架構(gòu)ARMv8的部分技術(shù)細(xì)節(jié)(也就是我們常說(shuō)的Cortex-A57A53)了讨,代表著未來(lái)移動(dòng)處理器邁入64位行列。我們得明確一點(diǎn)制轰,ARM公司自己本身并沒(méi)有64位芯片設(shè)計(jì)技術(shù)前计,他是通過(guò)了收購(gòu)MIPS64處理器架構(gòu)的部分技術(shù)使用權(quán),再結(jié)合ARM的一些特性設(shè)計(jì)出來(lái)的垃杖。也就是說(shuō):MIPS男杈、ARM、X86三大架構(gòu)中调俘,唯一沒(méi)有64位技術(shù)的ARM势就,通過(guò)收購(gòu)MIPS的形式得到了64位。
介紹參考資源如下:
http://www.reibang.com/p/34ee91ae5547
寶劍鋒從磨礪出脉漏,梅花香自苦寒來(lái)