1.區(qū)別
? ?這三者都表示的是CPU類型视粮,早期的Android系統(tǒng)幾乎只支持ARMv5的CPU架構,但是現(xiàn)在已經有7種了橙凳。ARMv5蕾殴,ARMv7 (從2010年起),x86 (從2011年起)岛啸,MIPS (從2012年起)钓觉,ARMv8,MIPS64和x86_64 (從2014年起)坚踩,每一種都關聯(lián)著一個相應的ABI(應用程序二進制接口(ApplicationBinary Interface)定義了二進制文件(尤其是.so文件)如何運行在相應的系統(tǒng)平臺上荡灾,從使用的指令集,內存對齊到可用的系統(tǒng)函數(shù)庫)瞬铸。Android現(xiàn)在的主流CPU是armeabi-v7a批幌。armeabi-v7a是針對有浮點運算或高級擴展功能的ARMv7 CPU。
2.Android設備如何加載.so文件
? ?當一個應用安裝在設備上赴捞,只有該設備支持的CPU架構對應的.so文件會被安裝逼裆。不同CPU架構的Android手機加載時會在libs下找自己對應的目錄,從對應的目錄下尋找需要的.so文件赦政;如果沒有對應的目錄胜宇,就會去armeabi下去尋找耀怜,如果已經有對應的目錄,但是如果沒有找到對應的.so文件桐愉,也不會去armeabi下去尋找了财破。
? ?以x86設備為例,x86設備會在項目中的 libs文件夾尋找是否含有x86文件夾从诲,如果含有x86文件夾左痢,則默認為該項目有x86對應的so可運行文件,只有x86文件夾而文件夾下沒有so系洛,程序運行也是會出現(xiàn)findlibrary returned null的錯誤的俊性;如果工程本身不含有x86文件夾,則會尋找armeabi或者armeabi-v7a文件夾描扯,兼容運行定页。以armeabi-v7a設備為例,該Android設備當然優(yōu)先尋找libs目錄下的armeabi-v7a文件夾绽诚,同樣典徊,如果只有armeabi-v7a文件夾而沒有 so也是會報錯的;如果找不到armeabi-v7a文件夾恩够,則尋找armeabi文件夾卒落,兼容運行該文件夾下的so,但是不能兼容運行x86的so蜂桶。所以項目中如果只含有x86的so儡毕,在armeabi和armeabi-v7a也是無法運行的。以上就是不同CPU架構運行時加載so的策略屎飘。
3.適配不同的平臺
? ?目前主流的Android設備是armeabi-v7a架構的妥曲,然后就是x86和armeabi了贾费。如果同時包含了 armeabi钦购,armeabi-v7a和x86,所有設備都可以運行褂萧,程序在運行的時候去加載不同平臺對應的so押桃,這是較為完美的一種解決方案,但是同時也會導致包變大导犹。
? ?armeabi-v7a是可以兼容armeabi的唱凯,而v7a的CPU支持硬件浮點運算,目前絕大對數(shù)設備已經是armeabi-v7a了谎痢,所以為了性能上的更優(yōu)磕昼,就不要為了兼容放到armeabi下了。x86也是可以兼容armeabi平臺運行的节猿,另外需要指出的是票从,打出包的x86的so漫雕,總會比armeabi平臺的體積更小,對于性能有潔癖的童鞋們峰鄙,還是建議在打包so的時候支持x86浸间。
4.第三方平臺的.so庫怎么處理
? ?第三方的類庫只提供了armeabi下的.so文件,我們項目里適配了armeabi-v7a和x86吟榴,如果不在對應的文件下放對應的.so文件魁蒜,就可能導致某些Android設備會出一些問題,我們可以復制armeabi下得.so文件到不同的文件夾下吩翻。如果第三方提供了不同平臺的.so文件兜看,則復制不同平臺的.so文件到項目中對應的文件夾下即可。
? ?關于.so文件之前有一個坑狭瞎,svn會把提交的so文件過濾掉铣减,在接第三方SDK的時候通過SVN更新了文檔,但是沒有注意到少了幾個so文件脚作,浪費了大把的時間去找原因葫哗。記得去掉svn對so的忽略!G蛱巍劣针!
兼容問題可以參考這篇文章:
Android 關于arm64-v8a、armeabi-v7a亿扁、armeabi捺典、x86下的so文件兼容問題