java.lang.UnsatisfiedLinkError: 的問題
集中回復
導致產生unsatisfiedlink的幾個原因
1. 相關信息
hyphenatechatsdk提供的指令集類型僅提供armeabi, arm64-v8a, x86三種蜕猫,這里需要解釋一下相關信息。
armeabi和armeabi-v7a是相近似的指令集校焦,v7a是增強型指令集磺芭,運行速度报强,效率均有所提高懒鉴,他們都是32位指令,并且兼容瞻离。
arm64-v8a對應arm 64位指令集腾仅,arm的64位策略和intel IA32不一樣,intel的64位指令是兼容32位指令套利,32位指令編譯的程序可以直接在64位機器上運行推励。
但是arm不是,arm64位和arm32位是彼此獨立的指令系統(tǒng)肉迫,不兼容验辞。arm這樣設計的原因是因為運行在嵌入式上,設計指標更趨向于效率喊衫,和耗電考量跌造。
實際上arm64位芯片上同時包含著64指令處理器,和32位指令處理器族购,只不過兩個處理器彼此獨立壳贪。
2. 影響鏈接的限制條件
armeabi的so實際上可以運行在64位機器上,只不過google增加了限制條件寝杖。
a. Android4.x, 只要能找到so违施,就可以運行,so可以在armeabi,armeabi-v7a, arm64-v8a朝墩,so位置可以很隨意醉拓。
b. Android5.x開始伟姐,檢查更加嚴格,會只有和芯片型號對應目錄的so會安裝到手機中亿卤。
舉個例子愤兵,開發(fā)環(huán)境下目錄結構如下
libs/armeabi/: libhyphenate.so libhyphenate_av.so
libs/armeabi-v7a: libmediadata.so
手機對應的指令集是armeabi-v7a,之中安裝到手機的只有l(wèi)ibmediadata.so
c. Android6.x下,檢查更加嚴格排吴。有一條規(guī)則秆乳,之前測試又遇到,現(xiàn)在不太確認钻哩。
libs/armeabi/: libhyphenate.so libhyphenate_av.so屹堰。
libs/arm64-v8a (沒有此目錄)。
在64位機器上也可以運行街氢。
但是作為開發(fā)者通常會依賴其他開發(fā)包扯键,比如baiduMap,也會用其他so,不能讓所有開發(fā)者都刪掉libs/arm64-v8a的目錄珊肃。
不過開發(fā)者可以嘗試下刪除arm64-v8a荣刑,只留armeabi,這樣安裝包會很小伦乔,在各個平臺上也能運行厉亏。google考量點是執(zhí)行速率,更流暢的用戶體驗烈和,作為開發(fā)者爱只。服務提供者,我們希望apk盡可能小招刹,對執(zhí)行速度要求不高恬试。
d. armeabi和armeabi-v7a可以互換,現(xiàn)在市面上的手機很少有armeabi的疯暑,基本上是armeabi-v7a忘渔,或者64位的高端機器。
e. 查看手機芯片型號: cat /proc/cpuinfo, 仔細看一下打印信息缰儿,能夠看明白手機指令集,是32位還是64位散址。
f. x86目錄乖阵,通常對應虛擬機,很多開發(fā)者喜歡在genymotion上開發(fā)調試预麸,這個就對應x86. x86和前面說的intel IA32是一回事瞪浸,所以只提供32位的,也能在x86-64位機器上運行吏祸。
g. 我們的so還依賴于libsqlite.so对蒲,不過由于這個包從來沒有變化,使用的是系統(tǒng)默認提供的(/system/lib/)。在Android 6.x及以下的平臺可以運行蹈矮。
Android7.x執(zhí)行更嚴格的安全檢查砰逻,禁止使用系統(tǒng)目錄的內容。所以如果希望在7.x以上版本泛鸟,需要把系統(tǒng)目錄的libsqlite.so拷貝出來蝠咆,也放在自己app對應指令目錄下。
由于目前Android7.x市面上沒有機型北滥,所以目前不在考慮范圍刚操。目前微信...等大app都不能在7.x上運行。
i. mips指令集的手機很少見再芋,聽說聯(lián)想有出過菊霜,沒見過。
h. libs/armeabi/libhyphenate.so 和libs.without.audio/armeabi/libhyphenate.so是不同济赎,libs/armeabi/libhyphenate.sos會依賴于libs/armeabi/libhyphenate_av.so鉴逞,如果找不到會報java.lang.UnsatisfiedLinkError.