RM新时代网站-首页

0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
創(chuàng)作中心

完善資料讓更多小伙伴認識你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

基于MacroBenchmark的性能測試量化指標方案

jf_uPRfTJDa ? 來源: 移動Labs ? 2023-10-17 10:15 ? 次閱讀

Labs 導讀

基于Benchmark的性能測試量化指標方案是一種用于評估和量化系統(tǒng)性能的方法。通過使用Benchmark測試工具,該方案旨在提供可靠的性能數(shù)據(jù),并使用具體的指標來衡量系統(tǒng)在各個方面的表現(xiàn)。本文將介紹基于Google MacroBenchmark的性能量化指標測試的工程配置、測試流程、核心指標和應用案例,幫助Android 開發(fā)者更好地評估和比較App的性能。

作者:孫仁偉

單位:中國移動智慧家庭運營中心

Part 01背景

隨著App業(yè)務不斷增長和功能的迭代,代碼量快速增加,導致應用結(jié)構(gòu)復雜度提高。同時,在App開發(fā)過程中,與競爭對手的App進行性能比較也是必要的。為了避免代碼增長和功能迭代帶來的性能下降,我們需要一套技術(shù)方案來監(jiān)控App版本的性能,以指導開發(fā)人員及時進行代碼重構(gòu)。

Part 02方案說明

Benchmark,即基準測試,是檢查和監(jiān)控應用性能的一種方式。通過對每個移動App版本的迭代運行基準測試,可以幫助分析和調(diào)試性能問題,并確保迭代的更改不會引起性能下降。

以下是一些常見的移動App的benchmark方法和工具:

1.Startup Time Benchmark:評估應用程序的啟動時間,即從用戶點擊應用圖標到應用程序完全加載并可交互的時間??梢允褂酶鞣N工具和方法來測量啟動時間,如使用應用性能監(jiān)測工具或手動計時。

2.Responsiveness Benchmark:評估應用程序?qū)τ脩舨僮鞯捻憫俣?,包括用戶界面的流暢度和操作的延遲??梢允褂眯阅鼙O(jiān)測工具記錄用戶操作和應用程序響應時間,或者進行用戶體驗測試來評估應用的響應性能。

3.Memory Usage Benchmark:評估應用程序在運行過程中使用的內(nèi)存量。可以使用內(nèi)存分析工具來監(jiān)測應用程序的內(nèi)存使用情況,并進行比較和分析。

4.Battery Consumption Benchmark:評估應用程序?qū)υO(shè)備電池的消耗情況??梢允褂秒姵叵谋O(jiān)測工具來測量應用程序在不同使用情景下的電池消耗量,并進行比較和分析。

5.Network Performance Benchmark:評估應用程序在使用網(wǎng)絡功能時的性能和速度??梢允褂镁W(wǎng)絡性能監(jiān)測工具來模擬不同網(wǎng)絡條件下的應用性能,并進行測試和比較。

針對Startup Time Benchmark和Responsiveness Benchmark,Google提供了Macrobenchmark庫,該庫主要用于評估Android App整體性能的基準測試。其旨在模擬真實世界的使用情景,通過測試用例以涵蓋各種應用使用過程中交互操作,以綜合評估應用的性能和響應能力。

2.1 Macrobenchmark

2.1.1 設(shè)置Macrobenchmark

1. 打開應用Application工程,在 Android Studio 的 Project 面板中右鍵點擊項目或模塊,然后依次點擊 New > Module。

2. 從Templates窗格中選擇 Benchmark。

3. 自定義目標應用(要進行基準測試的應用),以及新的Macrobenchmark模塊的軟件包和模塊名稱。

4. 點擊Finish,從而創(chuàng)建Macrobenchmark Module。

8ce88210-6b2e-11ee-939d-92fbcf53809c.png

2.1.2 創(chuàng)建Macrobenchmark類

在Macrobenchmark,我們根據(jù)業(yè)務自身情況,創(chuàng)建所需的性能指標Benchmark測試用例。測試用例可以基于Macrobenchmark 庫中的`MacrobenchmarkRule` JUnit4規(guī)則所含的API實現(xiàn)。

比如我們現(xiàn)在需要對App應用啟動時間進行監(jiān)控。則可以在Macrobenchmark Module編寫一個測試用例類,在測試用例類中編寫測試用例方案,如測量5次打開應用時間。

創(chuàng)建startup測試用例,該用例基于MacrobenchmarkRule.measureRepated。

8d01c842-6b2e-11ee-939d-92fbcf53809c.png

其中各參數(shù)

packageName:App的包名;

metrics:測量度量。此處我們選擇 StartupTimeMetric,標識測量啟動時長;

iterations:重復次數(shù)。表示該項用例的測試次數(shù),可以通過多次測量取均值的方式,避免單次測量的偏差影響;

setupBlock:用例前置操作。;

最后的 {} :用例內(nèi)容。此處我們執(zhí)行 startActivityAndWait,表示啟動App并等待啟動完成,App首幀顯示。

2.1.3 運行基準

在Android Studio中運行測試,以衡量應用在設(shè)備上的性能??梢韵袷褂脺y試類或方法旁邊的邊線操作運行任何其他 `@Test` 一樣運行基準,如下圖所示。

8d1403a4-6b2e-11ee-939d-92fbcf53809c.png

也可以通過`gradle`命令,從命令行運行Gradle模塊中的所有基準:

8d291de8-6b2e-11ee-939d-92fbcf53809c.png

2.1.4 基準結(jié)果

基準運行成功后,指標會直接顯示在Android Studio中,還會以JSON文件形式輸出以供持續(xù)集成環(huán)境使用。

每次衡量的迭代過程均會捕獲單獨的系統(tǒng)跟蹤文件。點擊Test Results窗格中的其中一個鏈接,可以打開這些結(jié)果跟蹤文件,如下圖所示。即平均啟動時長為748.1ms。

8d3a8eca-6b2e-11ee-939d-92fbcf53809c.png

跟蹤文件加載完成后,Android Studio會提示您選擇要分析的進程。系統(tǒng)會預先填充目標應用進程:

8d501b64-6b2e-11ee-939d-92fbcf53809c.png

跟蹤文件加載完成后,Studio將在CPU性能剖析器工具中顯示結(jié)果:

8d64bb1e-6b2e-11ee-939d-92fbcf53809c.png

Part 03應用實例

在實驗工程中,在Application.onCreate中增加了200ms睡眠。

運行實驗工程,構(gòu)建App,運行App,運行Macrobenchmark。在CPU性能剖析器工具中可以看到主線程在app.onCreate方法執(zhí)行時耗時達223.12ms。

8d76e708-6b2e-11ee-939d-92fbcf53809c.png

通過分析CPU性能剖析器工具 的示圖,可以判斷app.onCreate 時,主線程存在約200ms異常時延。再閱讀相關(guān)代碼,可以查出該異常部分的睡眠邏輯。

將該異常睡眠邏輯移除,從新運行實驗工程,構(gòu)建App,運行App,運行Macrobenchmark。

在CPU性能CPU性能剖析器工具中可以看到主線程在app.onCreate方法耗時約為22.01ms,時延正常,方法執(zhí)行過程中只執(zhí)行了相關(guān)調(diào)用方法,說明問題得到了修復。

8d87e490-6b2e-11ee-939d-92fbcf53809c.png

通過以上案例,我們可以看出通過Macrobenchmark + CPU性能剖析器工具, 我們可以對應用特定場景進行時延分析,并對新增時延進行有效歸因,從而能針對性的進行優(yōu)化處理。

審核編輯:湯梓紅

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學習之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報投訴
  • Android
    +關(guān)注

    關(guān)注

    12

    文章

    3935

    瀏覽量

    127335
  • APP
    APP
    +關(guān)注

    關(guān)注

    33

    文章

    1573

    瀏覽量

    72437
  • 中國移動
    +關(guān)注

    關(guān)注

    22

    文章

    5548

    瀏覽量

    71089
  • 性能測試
    +關(guān)注

    關(guān)注

    0

    文章

    209

    瀏覽量

    21327

原文標題:技術(shù) | 基于MacroBenchmark的性能測試量化指標方案

文章出處:【微信號:5G通信,微信公眾號:5G通信】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。

收藏 人收藏

    評論

    相關(guān)推薦

    射頻電纜及測試電纜組件的性能指標

    該文詳細討論了射頻電纜及測試電纜組件的各項指標性能,為廣大測試工程人員在選用高性能高可靠性射頻測試
    發(fā)表于 10-30 11:28 ?1783次閱讀

    Linux性能測試性能測試指標詳解

    性能測試指標是衡量系統(tǒng)性能的評價標準,常用的系統(tǒng)性能測試指標
    發(fā)表于 12-23 14:50 ?598次閱讀

    性能指標測試

    性能指標測試
    發(fā)表于 08-17 14:51

    請問ZIGBEE的硬件性能指標都要測試哪些內(nèi)容

    我們公司買了一臺萊特波特的IQxel ,現(xiàn)在要用來測試ZIGBEE 的射頻,想問一下ZIGBEE 硬件性能指標都要測試哪些內(nèi)容,在多少范圍才算是一個良好的ZIGBEE模塊
    發(fā)表于 08-17 06:11

    性能充放電方案在電池測試設(shè)備中的應用

    及內(nèi)阻等指標進行測試,對于電池測試設(shè)備的系統(tǒng)設(shè)計最重要的三個指標是充放電精度,成本和轉(zhuǎn)換效率。 對于電池測試設(shè)備的核心功能電池充放電,市面上
    發(fā)表于 11-08 06:36

    INT8量化常見問題的解決方案

    一、int8的輸出和fp32模型輸出差異比較大 解決方案: 檢查前后處理是否有問題,int8網(wǎng)絡輸入輸出一般需要做scale處理,看看是否遺漏? 通過量化可視化工具分析int8的輸出和fp32
    發(fā)表于 09-19 06:09

    數(shù)據(jù)庫性能評測指標及其測試方法

    近些年來,國產(chǎn)數(shù)據(jù)庫得到了快速的發(fā)展,但是針對其性能測試方法和測試指標卻參差不齊。針對上述問題,中國軟件評測中心在大量數(shù)據(jù)庫測試的基礎(chǔ)之上
    發(fā)表于 03-17 15:22 ?79次下載

    關(guān)于UV膠理化指標性能測試方法的介紹

    幾種常見的UV膠水性能測試方法,希望對大家有所幫助! 目前UV膠水的理化指標可大致分為:外觀、密度、粘度、硬度、力學性能等,具體性能
    發(fā)表于 01-19 11:14 ?6145次閱讀

    電纜性能指標測試方法

    熟悉電纜電性能指標種類及定義; 掌握電纜電性能指標測試方法; 建立電纜重要性能指標的檢驗常態(tài)化機制。
    發(fā)表于 06-22 10:19 ?15次下載

    軟件性能測試常見指標

    軟件性能測試是指測試I程師運用各種自動化測試工具在正常、峰值或者特殊異常情況下對系統(tǒng)軟件進行測試,以檢測系統(tǒng)的
    的頭像 發(fā)表于 10-31 17:44 ?1361次閱讀

    軟件性能測試常見指標。在哪里測試測試?

    軟件性能測試是指測試I程師運用各種自動化測試工具在正常、峰值或者特殊異常情況下對系統(tǒng)軟件進行測試,以檢測系統(tǒng)的
    發(fā)表于 12-22 23:13 ?391次閱讀

    軟件性能測試方案怎么編寫?

    一、軟件性能測試方案是什么? 軟件性能測試方案是針對軟件產(chǎn)品開展
    的頭像 發(fā)表于 02-28 15:04 ?2024次閱讀

    射頻測試線纜的性能指標有哪些?

    射頻測試線纜是一種用于連接測試儀器和被測器件的線纜,其性能直接影響測試結(jié)果的準確性。因此,了解射頻測試線纜的
    的頭像 發(fā)表于 04-07 14:35 ?3.2w次閱讀

    半導體IC測試解決方案測試指標包含哪些?

    半導體IC測試解決方案測試指標包含哪些? 半導體IC測試解決方案
    的頭像 發(fā)表于 11-09 09:24 ?958次閱讀

    性能測試主要測什么 性能測試指標有哪些

    性能測試是軟件測試的一個重要組成部分,主要用于評估軟件系統(tǒng)在各種負載條件下的性能表現(xiàn)。性能測試
    的頭像 發(fā)表于 05-29 15:42 ?2297次閱讀
    RM新时代网站-首页