如今來講,那就又是去年的事情了。到目前爲止,androidx 庫不少版本已經推出了正式穩定版,版本詳情戳這裏。對比之前 support 包, androidx 將各個 library 分開設立單獨的版本管理,這樣的好處顯而易見。第一沒有了以前 v4 v7 的繁瑣依賴。第二能夠精確指定須要導入 library ,避免沒必要要的導入,從而減小代碼體積。關鍵新的 library 版本徹底遵循 Semantic Versioning,而不是跟着 Android API 版本走。這樣讓咱們經過版本號就能明確和當前代碼是否兼容。html
還有一點,如今不少開源項目已經陸續完成 androidx 遷移,而且基本再也不對 support 提供最新支持。若是你不跟上這個節奏,那麼從此你就無法升級相關依賴,老版本 bug 修復你也得不到任何支持。android
遷移已經超級超級簡單。Google 已經考慮到咱們的遷移成本,在 Android Studio 中已經支持一鍵遷移。git
這個的前提是你得更新你的 Android Studio 版本和 gradle 的版本。請注意,這兩個的版本都要更新。Android Studio 最低要求是 3.2 的版本,如今正式穩定版本是 3.4.1 ,gradle 支持 androidx 的最低版本是 3.2.1 ,請注意,必定要升級對應的 gradle 版本。github
接着就在頂部菜單欄中選擇 Refactor > Migrate to AndroidX 就能夠完成相關遷移啦,這時候會出現一個提示框。android-studio
備份那個勾選能夠去掉,而後點擊 Migrate 。接下來 Android Studio 會遍歷你的工程文件,進行相關包名和導包替換,而且會在你的 gradle.propertier 文件中增長兩個屬性。markdown
android.useAndroidX=true
android.enableJetifier=true
複製代碼
上面說了,項目導包啥的都會自動替換,你本身肯定就行。那麼依賴的庫呢,enableJetifier 這個屬性設置爲 true 時就會將你依賴的庫在打包時自動替換爲對應的 androidx ,是否是很流弊。詳情請看官方文檔app
遷移完成,build.gradle 中的相關依賴也會自動更換,不過它更換的版本可能不是對應的穩定版本,而是最新的 beta 版本,我們得手動更新到對應的穩定版本。那麼這個穩定版本是多少呢,去查看相關文檔是否是很糾結。已經有人幫我作了對應插件,超帥。oop
還有 @NonNull ,在新版本中非空可空都已添加明確註解,這些細節地方可能也須要手動去更新下。gradle
傻瓜式遷移搞定後,一切來得太快太順利都讓本身開始懷疑遷移是否完成,項目是否還 OK 。ui
驗證其實也很簡單,首先,你得驗證項目能編譯過,沒有 error ,lint 沒有額外的警告。個人經驗是遷移以後,導包更換成功,可是使用該類時又會帶上全路徑,這個時候 lint 是能刷出來的,須要手動改一改。接着,你得肯定 support 包是否已經被徹底替換,不該該出現二者共存的狀況。這裏就有不少方法,我提供三種方案:直接查看工程文件最下方的 External Libraries 是否還有 support 依賴;使用 ./gradlew -q :app:dependencies > dependencies.txt'
看看對應依賴關係中是否還有 support 依賴;反編譯本身的包,看看裏面還有沒有 support 相關的類。