來了!Android應用市場64位應用策略

語言: CN / TW / HK

作者:熊熊君fly 連結:https://juejin.cn/post/7023286220662767624

1 、背景

2019年8月1號,在Google Play上釋出應用必須支援64位架構,緊接著 小米應用商店、OPPO應用商店、vivo應用商店、騰訊應用寶和百度手機助手等五大應用商店宣佈,為更好提升App效能體驗並降低功耗,五方將共同推進國內安卓生態對64位架構的升級支援。

具體的時間表:

  • 2021年12月底,現有和新發布的應用、遊戲,需要上傳包含64位包體的APK包。也就是說所有上傳的應用都應該包含64位程式碼的版本,不再接受僅有32位版本的應用上傳。

  • 2022年8月底,對於支援64位的硬體系統,將只接收64位版本的APK包。也就是如果到時使用者手中的硬體裝置支援64位系統的話,那麼將只執行64位版本的應用。

  • 2023年底,硬體將僅支援64位APK,32位應用無法在終端上執行。

大勢所趨,以後釋出的應用要支援64位系統,

2、調研

現狀

目前手機cpu架構是 armeabiarmeabi-v7aarm64-v8ax86x86_64 ,但是目前手機基本上都是arm架構,x86架構的手機基本上沒有,基本上是平板,可以忽略。

armeabi是十年前的手機CPU架構,基本上沒有了。

armeabi-v7a的CPU架構是32位。

Arm64-v8a的CPU架構是64位。

所以目前需要考慮的 armeabi-v7aarm64-v8a 這兩款就可以了, 之前開發者在打包的時候,為了包大小的考慮,常常指定打包的時候,只指定 armeabi-v7a 架構的so包,這樣包大小可以小很多,尤其是so庫多的應用

ndk {
// 選擇要新增的對應 cpu 型別的 .so 庫,多個abi以“,”分隔。
abiFilters 'armeabi-v7a'
// 可指定的值為 'armeabi-v7a', 'arm64-v8a', 'armeabi', 'x86', 'x86_64'
}

在專案的gradle中配置ndk就可以,64位的手機會自適應32位的應用,這樣可以完美的相容市面上99.9%的手機,這樣包大小也會小很多 但是這樣64位處理器的效能就無法完美的發揮出來,那麼應用64位有哪些好處呢?

由於一些軟體功能越來越多,安裝包的體積、執行時需要消耗的執行記憶體越來越大,32位應用的侷限性越來越突出。而64位系統,可以在單個執行緒裡使用超過4GB的執行記憶體,當處理一些大型軟體、或者進行高畫素影象、影片處理的時候,就更能夠發揮手機硬體的優勢。比如一些大型遊戲、網路影片直播、高畫質影音播放等等。而且64位系統相比32位系統,會帶來至少20%以上效率的提升。

打入64位的so包必然導致包大小增大很多,導致使用者下載體驗差,目前Google paly支援上傳32位和64位的兩個apk,這樣使用者可以根據手機cpu架構動態的下載那個apk

國內市場暫不支援,但是這個是趨勢,之後必然要上這個功能的,我們在開發的時候,暫時還需要支援'armeabi-v7a', 'arm64-v8a’兩個架構,包大小也會增大很多

3、 處理方案

小米應用商店支援64位架構適配指南: https://dev.mi.com/distribute/doc/details?pId=1244

vivo應用商店64位架構適配指南: https://dev.vivo.com.cn/documentCenter/doc/511

oppo應用商店64位架構適配指南: https://open.oppomobile.com/wiki/doc#id=10948

若要確定應用是否包含 64 位庫,最簡單的方法就是檢查 APK 檔案的結構。在構建時,APK 會與應用所需的所有原生庫打包在一起。原生庫會根據 ABI 儲存在不同的資料夾中。您的應用不一定要支援所有 64 位架構,但對於支援的每種原生 32 位架構,應用都必須包含相應的 64 位架構。對於 ARM 架構, 32 位庫位於  armeabi-v7a 中。對應的 64 位庫則位於  arm64-v8a 中。

對於 x86 架構, 32 位庫位於  x86 中,64 位庫則位於 x86_64 中。

那麼如何檢視apk的架構

點選打出來的apk包,就會出現在目前的apk架構

build.gradle 中把ndk的依賴修改,依賴 'armeabi-v7a' , 'arm64-v8a'

ndk {
// 選擇要新增的對應 cpu 型別的 .so 庫,多個abi以“,”分隔。
abiFilters 'armeabi-v7a', 'arm64-v8a'
// 可指定的值為 'armeabi-v7a', 'arm64-v8a', 'armeabi', 'x86', 'x86_64'
}

打出的包的結果

打出的包需要在64位測試機上測試,如何檢視自己的的android手機的CPU架構呢?

檢視Android裝置的CPU架構資訊,可以使用命令來完成:

  • 1、 adb shell

  • 2、 cat /proc/cpuinfo

CPU architecture: 7表示arm-v78表示arm-v8

AArch64是ARMv8 架構的一種執行狀態。