您好,登錄后才能下訂單哦!
這篇文章將為大家詳細講解有關Android中Lint的原理是什么,文章內容質量較高,因此小編分享給大家做個參考,希望大家閱讀完這篇文章后對相關知識有一定的了解。
lint 工具的代碼掃描工作流:
應用源文件:源文件包含組成 Android 項目的文件,包括 Java、Kotlin 和 XML 文件、圖標以及 ProGuard 配置文件。
lint.xml 文件:一個配置文件,可用于指定要排除的任何 lint 檢查以及自定義問題嚴重級別。lint 工具:一個靜態代碼掃描工具,你可以從命令行或在 Android Studio 中對 Android 項目運行該工具。
lint 工具檢查可能會影響 Android 應用的質量和性能的代碼結構問題。強烈建議你先更正 lint 檢測到的所有錯誤,然后再發布你的應用。
lint 檢查結果:我們可以在控制臺或 Android Studio 的 Inspection Results 窗口中查看 lint 檢查結果。
Lint 的工作過程由 Lint Tool(檢測工具),Source Files(項目源文件) 和 lint.xml(配置文件) 三個部分組成,Lint Tool 讀取 Source Files,根據 lint.xml 配置的規則(issue)輸出最終的結果。
Lint 可以檢查并發現以下幾類問題:
缺少翻譯(和未使用的翻譯)
布局性能問題(所有以前實用 layoutopt 工具用來查找的問題,等等)
數組大小不一致
可訪問性和國際化問題(硬編碼字符串,缺少 contentDescription 等)
圖標問題(例如缺少密度,重復的圖標,錯誤的尺寸等)
可用性問題(如未在文本字段中指定輸入類型)
Manifest 錯誤
Lint 發現的每個問題都有描述信息和等級,我們可以很方便地定位問題,同時按照嚴重程度進行解決。當然,我們也可以手動配置每個問題的嚴重級別。Lint 本身包含大量已經封裝好的接口,能提供豐富的代碼信息,開發者可以基于這些信息進行自定義規則的編寫。
Lint 會按照問題的嚴重程度分為幾個等級:
Fatal
Error
Warning
Information
Ignore
問題嚴重程序由高到低依次降低。
如果你使用的是 Android Studio 或 Gradle,你可以在項目的根目錄下輸入以下某個命令,使用 Gradle 封裝容器對項目調用 lint 任務:
在 Windows 上:
gradlew lint
在 Linux 或 Mac 上:
./gradlew lint
lint 工具完成其檢查后,會提供 XML 和 HTML 版 lint 報告的路徑。然后,我們可以轉到 HTML 報告并在瀏覽器中將其打開
Lint 已經被集成到 Android Studio,所以可以直接使用,使用非常方便。lint 的代碼掃描工具,可幫助你發現并更正代碼結構質量的問題,而無需您實際執行應用,也不必編寫測試用例。系統會報告該工具檢測到的每個問題并提供問題的描述消息和嚴重級別,以便你可以快速確定需要優先進行的關鍵改進。此外,你還可以降低問題的嚴重級別以忽略與項目無關的問題,或者提高嚴重級別以突出特定問題。
從菜單欄,選擇Analyze > Inspect Code
選擇檢查范圍
選擇后,點擊"OK",稍等一會就會生成掃描結果:
左側是問題分類,選中一個問題條目,則右側會展示具體的問題代碼,這樣就可以很方便的進行問題排查、定位和更改了。
Android 的規則類別:
Accessibility 輔助選項,例如 ImageView 缺少 contentDescription 描述,String 編碼字符串等問題。
Compliance 合規性,違反了Google Play的要求,比如使用了過期的庫版本,性能、安全性、API等級等沒有遵循新系統的要求等。
Correctness 不夠完美的編碼,比如硬編碼、使用過時API等。
Internationalization 國際化,如直接使用漢字,沒有使用資源引用等。
Interoperability 互操作性,比如和Kotln的交互等。
Performance 性能,例如:靜態引用,循環引用等。
Security 安全性,例如沒有使用 HTTPS 連接 Gradle,AndroidManifest 中的權限問題等。
Usability 易用性,有更好的替換的,例如缺少某些倍數的切圖,排版、圖標格式建議.png格式等等。
我們可以在 lint.xml 文件中進行 lint 配置。我們可以手動創建該文件,并放置在 Android 項目的根目錄下。
lint.xml 文件由封閉的 父標記組成,此標記包含一個或多個 子元素。lint 會為每個 定義唯一的 id 屬性值。
<?xml version="1.0" encoding="UTF-8"?> <lint> <!-- list of issues to configure --> </lint>
我們可以通過在 標記中設置嚴重性級別屬性來更改某個問題的嚴重性級別或對該問題停用 lint 檢查。
下面來看一個示例:
<?xml version="1.0" encoding="UTF-8"?> <lint> <!-- Disable the given check in this project --> <issue id="IconMissingDensityFolder" severity="ignore" /> <!-- Ignore the ObsoleteLayoutParam issue in the specified files --> <issue id="ObsoleteLayoutParam"> <ignore path="res/layout/activation.xml" /> <ignore path="res/layout-xlarge/activation.xml" /> </issue> <!-- Ignore the UselessLeaf issue in the specified file --> <issue id="UselessLeaf"> <ignore path="res/layout/main.xml" /> </issue> <!-- Change the severity of hardcoded strings to "error" --> <issue id="HardcodedText" severity="error" /> </lint>
如果我們在 Android 項目中想對某個類或方法禁用 lint 檢查,可以請向該代碼添加 @SuppressLint 注解。
以下示例展示了如何對 onCreate 方法中的 NewApi 問題停用 lint 檢查。lint 工具會繼續檢查該類的其他方法中的 NewApi 問題。
@SuppressLint("NewApi") @Override public void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.main);
以下示例展示了如何對 FeedProvider 類中的 ParserError 問題停用 lint 檢查:
@SuppressLint("ParserError") public class FeedProvider extends ContentProvider {
要禁止 lint 檢查文件中的所有問題,請使用 all 關鍵字,如下所示:
@SuppressLint("all")
我們可以使用 tools:ignore 屬性對 XML 文件的特定部分停用 lint 檢查。在 lint.xml 文件中添加以下命名空間值,以便 lint 工具能夠識別該屬性:
namespace xmlns:tools="http://schemas.android.com/tools"
以下示例展示了如何對 XML 布局文件的 元素中的 UnusedResources 問題停用 lint 檢查。如果某個父元素聲明了 ignore 屬性,則該元素的子元素會繼承此屬性。在本示例中,也會對 子元素停用 lint 檢查。
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" xmlns:tools="http://schemas.android.com/tools" tools:ignore="UnusedResources" > <TextView android:text="@string/auto_update_prompt" /> </LinearLayout>
要禁止檢查多個問題,請使用以英文逗號分隔的字符串列出要禁止檢查的問題。例如:
tools:ignore="NewApi,StringFormatInvalid"
要禁止 lint 檢查 XML 元素中的所有問題,請使用 all 關鍵字,如下所示:
tools:ignore="all"
通過 Android Plugin for Gradle,我們可以使用模塊級 build.gradle 文件中的 lintOptions {} 代碼塊配置某些 lint 選項,例如要運行或忽略哪些檢查。
例如:
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 } } ...
我們可以很方便的在 Android Studio 中修改 lint 檢查時的配置。
Android Studio 附帶了許多 lint 及其他檢查配置文件,這些配置文件可通過 Android 更新進行更新。我們可以原封不動地使用這些配置文件,也可以修改它們的名稱、說明、嚴重級別和范圍。當然,還可以激活和禁用整組的配置文件或一組配置文件中的個別配置文件。
依次選擇 Analyze > Inspect Code,在 Specify Scope 對話框的 Inspection Profile 下,點擊 More。
此時將顯示 Inspections 對話框,其中列出了支持的檢查及其說明:
選擇 Profile 下拉列表,以在 Default (Android Studio) 與 Project Default(活動項目)檢查之間切換。
在左側窗格的 Inspections 對話框中,選擇一個頂級配置文件類別,或展開一個組并選擇特定的配置文件。選擇一個配置文件類別后,我們可以將該類別中的所有檢查項目當作一個檢查項目進行修改。
選擇 Manage 下拉列表,以復制檢查項目、對檢查項目進行重命名、向檢查項目添加說明以及導出/導入檢查項目。
操作完成后,點擊 OK。
關于Android中Lint的原理是什么就分享到這里了,希望以上內容可以對大家有一定的幫助,可以學到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。