Android:如何正確放置so庫(kù)文件

問(wèn)題描述

當(dāng)需要引用 so 庫(kù)的時(shí)候盆顾,正常情況下我們只需要將不同版本的 so 文件分別放置。但是這樣就會(huì)遇到兩個(gè)問(wèn)題:

  1. 如果每個(gè)架構(gòu)的 so 庫(kù)都放進(jìn)去嘲玫,會(huì)大大增加 apk 包的大小
  2. 如果偏偏沒(méi)有 arm-v7a 的版本呢僧鲁?是刪除 armeabi-v7a 目錄只保留 armeabi ?還是說(shuō)兩個(gè)目錄下 so 文件數(shù)不同也沒(méi)有關(guān)系牧氮?

首先了解一下 so 文件的類(lèi)型

so 文件的類(lèi)型

在 Android 系統(tǒng)中 ndk 默認(rèn)會(huì)生成如下 7 種 .so琼腔。

  • armeabi ARM:v5 第5代、第6代的ARM處理器踱葛,早期的手機(jī)用的比較多丹莲。缺少對(duì)浮點(diǎn)數(shù)計(jì)算的硬件支持,在需要大量計(jì)算時(shí)有性能瓶頸
  • armeabi-v7a:v7 目前主流版本尸诽,2011年15月以后的生產(chǎn)的大部分Android設(shè)備都使用它
  • arm64-v8a:第8代甥材、64位ARM處理器,很少設(shè)備性含,三星 Galaxy S6是其中之一
  • x86:平板洲赵、模擬器用得比較多
  • x86_64:x86架構(gòu)的64位。
  • mips:極少用于手機(jī)
  • mips64:mips架構(gòu)的64位

首先mips和mips64極少用于手機(jī)商蕴,因此可以忽略叠萍;x86和x86_64的架構(gòu)都會(huì)包含由 Intel 提供的稱(chēng)為 Houdini 的指令集動(dòng)態(tài)轉(zhuǎn)碼工具,實(shí)現(xiàn) 對(duì) arm 的兼容究恤,再考慮 x86 1% 以下的市場(chǎng)占有率俭令,x86 相關(guān)的兩個(gè) so 也是可以忽略的;arm64-v8a 是可以向下兼容的部宿,因此也是可以忽略的抄腔。

也就是說(shuō),項(xiàng)目中只需要保存兩種架構(gòu)即可:armeabi 和 armeabi-v7a理张。

android加載 so 庫(kù)的模式

比如當(dāng)前用戶(hù)的手機(jī)是 armeabi-v7a 的赫蛇,apk的armeabi包下有 a.so 和 b.so 兩個(gè)庫(kù),而 armeabi-v7a 包下只有 a.so 一個(gè)庫(kù)雾叭。

  1. android4.4 的so文件拷貝邏輯

android在掃描apk文件的時(shí)候悟耘,并沒(méi)有保證 zip entry 的掃描順序。加載 libs/<abi>/libxxx.so 時(shí)织狐,首先判斷這個(gè) so 庫(kù)是否是當(dāng)前CPU的架構(gòu)暂幼,如果是的話筏勒,則將一個(gè)類(lèi)似名為 hasPrimary 的 boolean 值置為 true ,然后將 so 庫(kù)拷貝到手機(jī)上旺嬉;如果不是的話管行,則判斷是否已經(jīng)加載過(guò)當(dāng)前CPU架構(gòu)的 so 庫(kù)了,即判斷 hasPrimary 的值邪媳,只有 hasPrimary 的值為 false 時(shí)捐顷,即還沒(méi)有加載過(guò)當(dāng)前CPU架構(gòu)的 so 庫(kù),則將這個(gè) so 庫(kù)拷貝到手機(jī)上雨效。

  • 如果首先掃描到 armeabi 包下的 a.so 庫(kù)迅涮,此時(shí)因?yàn)?hasPrimary 默認(rèn)為false,因此會(huì)將 a.so 庫(kù)拷貝到手機(jī)上徽龟,隨后 armeabi 下的 b.so 庫(kù)也會(huì)被拷貝到手機(jī)上
  • 如果首先掃描到 armeabi-v7a 包下的 a.so 庫(kù)叮姑,此時(shí)會(huì)將 hasPrimary 置為true,并將 a.so 庫(kù)拷貝到手機(jī)上顿肺,因?yàn)?hasPrimary 的值為 true 戏溺,后面也就不會(huì)拷貝 armeabi 包下的 b.so 庫(kù)了

因此有可能只會(huì)拷貝 armeabi-v7a 下的 a.so 庫(kù)到手機(jī)上,當(dāng)執(zhí)行 b.so 中的邏輯時(shí)屠尊,就會(huì)產(chǎn)生 crash

  1. android5.0+ 的 so 文件拷貝邏輯

不再以文件為粒度匹配,直接拷貝整個(gè)文件夾耕拷。因此只會(huì)將整個(gè) armeabi-v7a 包下的 so 庫(kù)拷貝讼昆,因此當(dāng)執(zhí)行 b.so 中的邏輯時(shí),也會(huì)產(chǎn)生crash

正確的放置方法

  • 為了減小 apk 體積骚烧,只保留 armeabi 和 armeabi-v7a 兩個(gè)文件夾浸赫,并保證這兩個(gè)文件夾中 so 數(shù)量一致
  • 對(duì)只提供 armeabi 版本的第三方 so,原樣復(fù)制一份到 armeabi-v7a 文件夾
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末赃绊,一起剝皮案震驚了整個(gè)濱河市既峡,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌碧查,老刑警劉巖运敢,帶你破解...
    沈念sama閱讀 217,084評(píng)論 6 503
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異忠售,居然都是意外死亡传惠,警方通過(guò)查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,623評(píng)論 3 392
  • 文/潘曉璐 我一進(jìn)店門(mén)稻扬,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)卦方,“玉大人,你說(shuō)我怎么就攤上這事泰佳∨慰常” “怎么了尘吗?”我有些...
    開(kāi)封第一講書(shū)人閱讀 163,450評(píng)論 0 353
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)浇坐。 經(jīng)常有香客問(wèn)我睬捶,道長(zhǎng),這世上最難降的妖魔是什么吗跋? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 58,322評(píng)論 1 293
  • 正文 為了忘掉前任侧戴,我火速辦了婚禮,結(jié)果婚禮上跌宛,老公的妹妹穿的比我還像新娘酗宋。我一直安慰自己,他們只是感情好疆拘,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,370評(píng)論 6 390
  • 文/花漫 我一把揭開(kāi)白布蜕猫。 她就那樣靜靜地躺著,像睡著了一般哎迄。 火紅的嫁衣襯著肌膚如雪回右。 梳的紋絲不亂的頭發(fā)上,一...
    開(kāi)封第一講書(shū)人閱讀 51,274評(píng)論 1 300
  • 那天漱挚,我揣著相機(jī)與錄音翔烁,去河邊找鬼。 笑死旨涝,一個(gè)胖子當(dāng)著我的面吹牛蹬屹,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播白华,決...
    沈念sama閱讀 40,126評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼慨默,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來(lái)了弧腥?” 一聲冷哼從身側(cè)響起厦取,我...
    開(kāi)封第一講書(shū)人閱讀 38,980評(píng)論 0 275
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎管搪,沒(méi)想到半個(gè)月后虾攻,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,414評(píng)論 1 313
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡抛蚤,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,599評(píng)論 3 334
  • 正文 我和宋清朗相戀三年台谢,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片岁经。...
    茶點(diǎn)故事閱讀 39,773評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡朋沮,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情樊拓,我是刑警寧澤纠亚,帶...
    沈念sama閱讀 35,470評(píng)論 5 344
  • 正文 年R本政府宣布,位于F島的核電站筋夏,受9級(jí)特大地震影響蒂胞,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜条篷,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,080評(píng)論 3 327
  • 文/蒙蒙 一骗随、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧赴叹,春花似錦鸿染、人聲如沸。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 31,713評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)。三九已至绽媒,卻和暖如春蚕冬,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背是辕。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 32,852評(píng)論 1 269
  • 我被黑心中介騙來(lái)泰國(guó)打工囤热, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人获三。 一個(gè)月前我還...
    沈念sama閱讀 47,865評(píng)論 2 370
  • 正文 我出身青樓赢乓,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親石窑。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,689評(píng)論 2 354

推薦閱讀更多精彩內(nèi)容