中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

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

發布時間:2020-07-09 22:36:02 來源:網絡 閱讀:3436 作者:一劍圍城 欄目:移動開發

問題:使用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       : AArch74 Processor rev 2 (aarch74)      arm64-v8a


問題一、Android支持哪些cpu架構?

答案很容易搜索到:android目前支持7種架構

  1. x86_64

  2. x86

  3. mips64

  4. mips

  5. armeabi-v7a

  6. armeabi

  7. 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庫文件。(查閱許多文檔都說x86是兼容armeabi的so文件的,驗證時必須保證x86文件夾為空,或者根本沒有x86文件夾)


向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

石柱| 伊金霍洛旗| 中方县| 图片| 麻阳| 新郑市| 苗栗县| 惠水县| 宜城市| 呼玛县| 汉源县| 桑植县| 卢氏县| 边坝县| 建阳市| 娄底市| 新乐市| 天祝| 兴业县| 连云港市| 英山县| 涟源市| 大冶市| 广东省| 三门峡市| 鹰潭市| 南昌市| 桓台县| 禹城市| 奉化市| 莱州市| 罗定市| 河南省| 黔西| 称多县| 常州市| 安化县| 繁峙县| 宜宾市| 鄯善县| 鄂托克前旗|