Android 最新 Support V4 包大拆分有用嗎?

Google 昨天更新了最新的 Support Library 版本,其中最爲顯眼的功能莫過於 support-v4 大拆分,然後這個拆分現在看來並沒有那麼美好。

v4 包從 2011 年開始引入,包含 ViewPager、FragmentActivity 等我們常用的功能,目前已經達到 1.3 M,Google 此次升級將這個庫拆分爲 5 個子的 Module,每個 Module 可以被單獨引用。

1. 子 Module 介紹

這裏寫圖片描述
五個子 Module 分別爲:
(1) support-compat
兼容一些 Framework API。如 Context.getDrawable() 和 View.performAccessibilityAction()。大小爲 602k。

(2) support-core-utils
提供一系列核心的工具,如 AsyncTaskLoader 和 PermissionChecker。大小爲 90k。

(3) support-core-ui
提供一系列核心的 UI,如 ViewPager、 NestedScrollView。大小爲 240k。

(4) support-media-compat
android.media 兼容庫,包括 MediaBrowser 和 MediaSession。大小爲 248k。

(5) support-fragment
fragment 的兼容庫,大小爲 136k。

2. 子 Module 間依賴關係

這裏寫圖片描述

PS:其中 support-annotations 爲一些註解的聲明庫,如我們比較常用的 RequiresApi、UiThread、NonNull。大小爲 21k。

從中可以看出 support-fragment 依賴於所有其他子 Module,而 support-v4 包含所有 Module,所以現在引入
compile 'com.android.support:support-fragment:24.2.0'
compile 'com.android.support:support-v4:24.2.0'
的效果是一樣的。

3. 問題

support-v4 拆分的好處第一眼看來便是能減少應用大小,因爲你不需要引用完整的 support-v4 包,只需要引用子的 Module 即可。

比如我只用了 AsyncTaskLoader,只需要引用 support-core-utils 即可,只有 90k 哎,比原來的 1.3M 降了一個數量級多,應用減少了 1M 多哎,然而真的這樣嗎?

(1) support-compat 過大
大家知道 AAR 的大小是不包含它的依賴大小的,所以 support-core-utils 90k 大小僅表示自己的代碼和資源總大小。

從上面的依賴關係可以看出它們都依賴 support-compat,而 support-compat 有 602k,它依賴的 support-annotations 還有 21k,這樣引用 support-core-utils 實際增大大小約爲 700k+。

這樣比 1.3M 還是少了一半,也不錯,然而還沒有結束。

(2) support-v4 觸角太深
v4 包從 2011 年開始出來,由於 ViewPager、FragmentActivity 等類,v4 被大量其他包引用,早已子孫遍全球,比如 v7 兼容包 appcompat-v7 就依賴 v4。

我們可以嘗試通過 exclude module 可以把 v7 中 v4 去掉,然並卵,v7 依賴 FragmentActivity 這個類,而 FragmentActivity 位於 v4 的 support-fragment 中,所以依賴變成這樣:

[crayon-5835f9bfd98ca507218810/]
上面介紹過現在 com.android.support:support-fragment 與 com.android.support:support-v4 已經幾乎無異,所以對於依賴 v7 的 App 來說這次的 v4 拆分不能帶來任何依賴包體積的精簡。

初步看來 data-binding 也依賴於 support-v4。

4. 好處

這樣看來 v4 包的拆分是否是 Google 的自娛自樂,對於開發者全無好處呢?我看並不是。

(1) 這個拆分本身對於 V4 包項目來說是好事
各模塊劃清各自功能邊界,充分解耦。

(2) 也許這個拆分只是開始

轉載地址:http://ju.outofmemory.cn/entry/276288

發佈了39 篇原創文章 · 獲贊 21 · 訪問量 11萬+
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章