Android 效能優化:使用 Lint 優化程式碼、去除多餘資源

範培華發表於2017-02-15

http://blog.csdn.net/u011240877/article/details/54141714

快來優化你的專案吧~

讀完本文你將瞭解到:

前言

在保證程式碼沒有功能問題,完成業務開發之餘,有追求的程式設計師還要追求程式碼的規範、可維護性。

今天,以“成為優秀的程式設計師”為目標的拭心將和大家一起精益求精,學習使用 Lint 優化我們的程式碼。

什麼是 Lint

Lint 是Android Studio 提供的 程式碼掃描分析工具,它可以幫助我們發現程式碼結構/質量問題,同時提供一些解決方案,而且這個過程不需要我們手寫測試用例。

Lint 發現的每個問題都有描述資訊和等級(和測試發現 bug 很相似),我們可以很方便地定位問題,同時按照嚴重程度進行解決。

當然這個“嚴重程度”我們可以手動調節,有些原則問題不容侵犯,必須提升到 error,而有的個別問題也可以無視,畢竟人非聖賢孰能無過嘛。

Lint 工作方式簡單介紹

Lint 會根據預先配置的檢測標準檢查我們 Android 專案的原始檔,發現潛在的 bug 或者可以優化的地方,優化的內容主要包括以下幾方面:

  • Correctness:不夠完美的編碼,比如硬編碼、使用過時 API 等
  • Performance:對效能有影響的編碼,比如:靜態引用,迴圈引用等
  • Internationalization:國際化,直接使用漢字,沒有使用資源引用等
  • Security:不安全的編碼,比如在 WebView 中允許使用 JavaScriptInterface 等

Lint 檢測程式碼的過程如下圖所示:

shixinzhang

  • App 原始檔:包括 Java 程式碼,XML 程式碼,圖示,以及 ProGuard 配置檔案等
  • lint.xml:Lint 檢測的執行標準配置檔案,我們可以修改它來允許或者禁止報告一些問題

從命令列執行 Lint

Lint 的命令很簡單:

lint [flags] <project directory>
  • 1
  • 1

Lint 也可以使用 Gradle 執行:

Windows:

gradlew lint
  • 1
  • 1

Mac:

./gradlew lint
  • 1
  • 1

具體命令列相關的操作這裡就不介紹了,因為這個過程實在太痛苦,上一張命令列執行 Lint 後得到的 XML 檔案截圖讓你體驗一下:

shixinzhang

看著渾身不舒服,想了解如何從命令列使用 Lint 的同學可以點選這裡前往官方學習。

我們還是直接進入 Lint 的 GUI 操作吧。

Android Studio 中使用 Lint

Android Studio 中內建了 Lint,我們小手一點就可以直接使用。

Lint 的使用路徑: 
工具欄 -> Analyze -> Inspect Code…

點選 Inspect Code 後會彈出檢查範圍的對話方塊:

shixinzhang

預設是檢查整個專案,我們可以點選 Custom scope 自定義檢查範圍。

點選右邊的下拉框,會出現以下選擇:

shixinzhang

分別有:

  • Project Files:所有專案檔案
  • Project Production Files:專案的程式碼檔案
  • Project Test Files:專案的測試檔案
  • OpenFiles:當前開啟的檔案
  • Module ‘app’:主要的 app 模組
  • Current File:當前檔案

除了內建的選項我們還可以自己選擇特定的類進行檢查,點選下圖中的紅色框部分:

shixinzhang

會彈出自定義範圍選擇框,預設是空的,我們可以點選左上角的“+”號新增一個檢查範圍:

這裡寫圖片描述 
Local:只能當前專案使用 
Shared:其他 Android Studio 專案也可以使用

我們選擇 Shared,然後起個帥氣的名字 “ShixinCuteLint”,預設按專案顯示,這時檢查的檔案數為 0 :

這裡寫圖片描述

上圖中右邊的四個按鈕表示要操作的型別:

  • Include:包括當前資料夾內的檔案,但不包括他的子資料夾
  • Include Recursively:包括當前資料夾以及它的子資料夾內所有的資料夾,遞迴新增
  • Exclude:移除當前資料夾,不包括子資料夾
  • Exclude Recursively:移除當前資料夾及所有子資料夾

我們點選左邊的 app 資料夾後,點選右邊的 Include Recursively 按鈕,把 app 下的所有檔案新增到檢查列表:

這裡寫圖片描述

可以看到,這時 app 下的檔案都變綠了,總共有 689 個資料夾要掃描。

點選 OK 進行檢測,稍等一會兒,會彈出 Inspection 對話方塊,顯示檢查結果,沒想到我的程式碼居然有 1769 個警告!這數字觸目驚心啊:

這裡寫圖片描述

我們主要關注紅框內的警告,先來看看我的程式碼 Performance 有什麼問題:

這裡寫圖片描述

哈哈,沒想到我還有這麼多進步空間!

上圖可以看到,Lint 真是神器,可以幫我們發現自己忽略或者沒有意識到的問題,尤其是效能方面,如果你覺得自己程式碼想優化又不知道從何做起,不妨讓 Lint 給你指指路。

團隊中建立程式碼規範利器:提升、降低問題的等級

雖然 Lint 可以幫我們檢查程式碼的問題,但多人合作時,我們更期望可以在寫程式碼時就發現問題、解決問題。

鑑於團隊成員中水平良莠不齊,靠個人意識有時候很難保證質量,這時可以修改 Lint 對於特定問題的警告等級,以最直觀的 IDE 提示來警醒成員。

Lint 的警告嚴重程度有以下幾種:

這裡寫圖片描述

  • Unused Entry:沒有使用的屬性,灰色,很不起眼
  • Typo:拼寫錯誤,綠色波浪下劃線,也不太起眼
  • Server Problem:伺服器錯誤?好像不是
  • Info:註釋文件,綠色,比較顯眼
  • Weak Warning:比較弱的警告,提示比較弱
  • Warning:警告,略微顯眼一點
  • Error:錯誤,最顯眼的一個

日常開發中,好一點的程式設計師會關注 Warning 的警告,根據警告優化程式碼,但那也只是很少一部分。但是紅色的 Error 就不一樣了,基本上看到就想要消滅掉。

我們拿命名拼寫錯誤舉個例子。

類、物件、遍歷拼寫錯誤看起來不是什麼問題,但是如果你見過大量的無意義或者錯誤命名,你一定會贊同我的接下來做法。

預設的拼寫錯誤是 Typo ,提示很弱,所以常被人忽略:

這裡寫圖片描述

上面的 String 型別變數 login 寫成了 logn,Lint 預設對拼寫錯誤是個下滑波浪線,很不起眼。我們修改一下。

開啟 Preferences/Settings,搜尋 Inspections,會出現 Lint 的檢測配置頁面:

這裡寫圖片描述

要修改拼寫的警告等級,搜尋“spelling”:

這裡寫圖片描述

然後選擇出現的 Typo,再點選右邊的 Severity 就是嚴重程度,改成 Error,OK。

這裡寫圖片描述

可以看到,現在拼寫錯誤就會出現紅色的錯誤警告了,讓你不好好寫變數名!

Lint 雖好,也不能貪杯。

Lint 就像是一個潔癖患者,雖然可以讓我們程式碼乾淨許多,但是如果真要把它提示的全解決,恐怕老闆要發怒了:給你發工資天天玩電腦,怎麼不出活呢?!

Lint 報的某些警告的確是沒必要,這時我們可以選擇忽略這些警告。忽略警告可以分兩種:

  1. 在 Java 程式碼中
  2. 在 XML 資料夾中

在 Java 程式碼中忽略 Lint 警告

忽略 Lint 警告的註解跟 @SuppressWarnings 很類似,@SuppressLint(“忽略的警告名稱”)。

下面的程式碼演示瞭如何忽略 Lint 對使用新 API 的警告:

@SuppressLint("NewApi")
@Override
public void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.main);
}
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6

要是你不清楚要忽略的警告具體是什麼名字,那就直接忽略 all,當然是當前類/方法/物件:

@SuppressLint("all")
  • 1
  • 1

在 XML程式碼中忽略 Lint 警告

只需兩步:

  1. xml 中宣告 tools 名稱空間
  2. 使用 tools:ignore=”忽略的警告名”

例如:

<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
              xmlns:tools="http://schemas.android.com/tools"
              tools:ignore="all"
              android:layout_width="match_parent"
              android:layout_height="match_parent"
              android:orientation="vertical"
              android:background="@color/white">
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7

Gradle 中配置 Lint

Gradle 中也可以配置 Lint 的關鍵操作,比如是否開啟 Lint 警告,或者關閉指定的警告。

在 module 下的 build.gradle 中新增 lintOptions{…}, 樣例程式碼如下:

android {
  ...
  lintOptions {
    // Turns off checks for the issue IDs you specify.
    disable 'TypographyFractions','TypographyQuotes'
    // Turns on checks for the issue IDs you specify. These checks are in
    // addition to the default lint checks.
    enable 'RtlHardcoded','RtlCompat', 'RtlEnabled'
    // To enable checks for only a subset of issue IDs and ignore all others,
    // list the issue IDs with the 'check' property instead. This property overrides
    // any issue IDs you enable or disable using the properties above.
    check 'NewApi', 'InlinedApi'
    // If set to true, turns off analysis progress reporting by lint.
    quiet true
    // if set to true (default), stops the build if errors are found.
    abortOnError false
    // if true, only report errors.
    ignoreWarnings true
  }
}
...
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21

自動刪除查詢出來的無用資原始檔

程式碼迭代版本一多,很容易會遺留一些無用的程式碼、資原始檔,我們可以使用 Lint 進行清除。

點選 Android Studio 工具欄 -> Analyze -> Run Inspection By Name..,輸入要檢測的內容,這裡是無用資源:

這裡寫圖片描述

然後選擇 Unused resources,再選擇範圍後就開始檢測。

檢測出這麼多無用檔案:

這裡寫圖片描述

注意,右邊有解決方法:Remove All Unused Resources,放個大圖顯眼一點:

這裡寫圖片描述

點選後,boom ,從此世界清靜了。


相關文章