一個Android多平臺問題兼容解決思路

問題:使用AS打出來的簽名包,在調(diào)試一直用的5.0的小米手機上可以正常運行,4.4的聯(lián)想手機上閃退,5.1的模擬器上閃退。

創(chuàng)新互聯(lián)建站專業(yè)為企業(yè)提供拜城網(wǎng)站建設(shè)、拜城做網(wǎng)站、拜城網(wǎng)站設(shè)計、拜城網(wǎng)站制作等企業(yè)網(wǎng)站建設(shè)、網(wǎng)頁設(shè)計與制作、拜城企業(yè)網(wǎng)站模板建站服務(wù),十年拜城做網(wǎng)站經(jīng)驗,不只是建網(wǎng)站,更提供有價值的思路和整體網(wǎng)絡(luò)服務(wù)。

拋出:java.lang.UnsatisfiedLinkError,ClassLoader找不到相關(guān)的so庫。

解決思路:

猜想跟CPU架構(gòu)有關(guān)系,查詢?nèi)缦拢╟at /proc/cpuinfo):

      模擬器:                     電腦使用的是Intel的cpu                         x86_64架構(gòu)

      聯(lián)想:Processor       : ARMv7 Processor rev 2 (v7l)                armeabi-v7a

      小米:Processor       : AArch74 Processor rev 2 (aarch74)      arm64-v8a

問題一、Android支持哪些cpu架構(gòu)?

答案很容易搜索到:android目前支持7種架構(gòu)

  1. x86_64

  2. x86

  3. mips64

  4. mips

  5. armeabi-v7a

  6. armeabi

  7. arm64-v8a

問題二、系統(tǒng)是怎么查找so庫的呢?

查找so庫規(guī)則:

      運行的時候,系統(tǒng)會到Jnidirs目錄里查找so庫,會根據(jù)當(dāng)前平臺架構(gòu)查找對應(yīng)的目錄。這里面有一個規(guī)則是這個問題的元兇。當(dāng)你只提供了armeabi目錄時,armeabi-v7a、arm64-v8a架構(gòu)的程序都會去armeabi里尋找,而當(dāng)你同時也提供了armeabi-v7a、armeabi-v8a目錄,而里面又不存在對應(yīng)的so庫時,系統(tǒng)就不會再去armeabi里面尋找了,直接找不到報錯。

      而簽名包里面這七個目錄都有,這個問題后面討論。

驗證猜想:

      將app-release.apk使用打包軟件打開,刪除其中的armeabi-v7a目錄,發(fā)現(xiàn)聯(lián)想手機可以正常運行了(去armeabi里面尋找了)。移除x86_64文件夾,模擬器可以正常運行(去x86里面尋找了)。

問題三、簽名包為什么七個目錄全都有?

      對應(yīng)Jnidirs目錄中的七個目錄。打開簽名包,發(fā)現(xiàn)這七個目錄都有。奇怪的是我的項目里只有x86、armeabi和arm64-v8a三個類型的so庫。打開其他的目錄發(fā)現(xiàn)都是只有一個so文件:libgenius_graphics.so。百思不得其解這個從何而來,查找build-gradle的時候發(fā)現(xiàn):compile 'net.qiujuer.genius:graphics:2.0.0-beta8' 非常相似,這是一個開源的UI庫。猜測是引入這個庫在編譯的時候自動生成各個平臺下的libgenius_graphics.so文件。移除之,rebuild,確實如此,只剩下原本的三個文件夾。

問題四、armeabi能否兼容x86平臺?

      而當(dāng)我連x86文件夾都移除,則根本不能安裝在模擬器上,提示:INSTALL_FAILED_NO_MATCHING_ABIS。證明x86架構(gòu)不會去尋找armeabi目錄。當(dāng)你想在x86的機器上運行app時,一定要獲得對應(yīng)的x86版本so庫文件。(查閱許多文檔都說x86是兼容armeabi的so文件的,驗證時必須保證x86文件夾為空,或者根本沒有x86文件夾)

本文標(biāo)題:一個Android多平臺問題兼容解決思路
本文鏈接:http://bm7419.com/article48/jcsjhp.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供標(biāo)簽優(yōu)化、網(wǎng)頁設(shè)計公司、域名注冊靜態(tài)網(wǎng)站、搜索引擎優(yōu)化、網(wǎng)站收錄

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)

手機網(wǎng)站建設(shè)