標籤:android 相容 armeabi arm64 cpu架構
問題:使用AS打出來的簽名包,在調試一直用的5.0的小米手機上可以正常運行,4.4的聯想手機上閃退,5.1的模擬器上閃退。
拋出:java.lang.UnsatisfiedLinkError,ClassLoader找不到相關的so庫。
解決思路:
猜想跟CPU架構有關係,查詢如下(cat /proc/cpuinfo):
模擬器: 電腦使用的是Intel的cpu x86_64架構
聯想:Processor : ARMv7 Processor rev 2 (v7l) armeabi-v7a
小米:Processor : AArch64 Processor rev 2 (aarch64) arm64-v8a
問題一、Android支援哪些cpu架構?
答案很容易搜尋到:android目前支援7種架構
x86_64
x86
mips64
mips
armeabi-v7a
armeabi
arm64-v8a
問題二、系統是怎麼尋找so庫的呢?
尋找so庫規則:
啟動並執行時候,系統會到Jnidirs目錄裡尋找so庫,會根據當前平台架構尋找對應的目錄。這裡面有一個規則是這個問題的元兇。當你只提供了armeabi目錄時,armeabi-v7a、arm64-v8a架構的程式都會去armeabi裡尋找,而當你同時也提供了armeabi-v7a、armeabi-v8a目錄,而裡面又不存在對應的so庫時,系統就不會再去armeabi裡面尋找了,直接找不到報錯。
而簽名包裡面這七個目錄都有,這個問題後面討論。
驗證猜想:
將app-release.apk使用打包軟體開啟,刪除其中的armeabi-v7a目錄,發現聯想手機可以正常運行了(去armeabi裡面尋找了)。移除x86_64檔案夾,模擬器可以正常運行(去x86裡面尋找了)。
問題三、簽名包為什麼七個目錄全都有?
對應Jnidirs目錄中的七個目錄。開啟簽名包,發現這七個目錄都有。奇怪的是我的項目裡只有x86、armeabi和arm64-v8a三個類型的so庫。開啟其他的目錄發現都是只有一個so檔案:libgenius_graphics.so。百思不得其解這個從何而來,尋找build-gradle的時候發現:compile ‘net.qiujuer.genius:graphics:2.0.0-beta8‘ 非常相似,這是一個開源的UI庫。猜測是引入這個庫在編譯的時候自動產生各個平台下的libgenius_graphics.so檔案。移除之,rebuild,確實如此,只剩下原本的三個檔案夾。
問題四、armeabi能否相容x86平台?
而當我連x86檔案夾都移除,則根本不能安裝在模擬器上,提示:INSTALL_FAILED_NO_MATCHING_ABIS。證明x86架構不會去尋找armeabi目錄。當你想在x86的機器上運行app時,一定要獲得對應的x86版本so庫檔案。
本文出自 “一劍圍城” 部落格,請務必保留此出處http://weijiancheng.blog.51cto.com/10190955/1891876
一個Android多平台問題相容解決思路