WPF性能優化:性能分析工具

来源:https://www.cnblogs.com/czwy/p/18041898
-Advertisement-
Play Games

前言: 在本篇 Taurus.MVC WebMVC 入門開發教程的第四篇文章中, 我們將學習如何實現數據列表的綁定,通過使用 List<Model> 來展示多個數據項。 我們將繼續使用 Taurus.Mvc 命名空間,同時探討如何在視圖中綁定並顯示一個 Model 列表。 步驟1:創建 Model ...


在硬體性能不斷提升的現在,軟體性能依舊是開發人員關註的重點。不同類型的程式關註的具體性能指標有所不同,伺服器程式註重吞吐量,游戲引擎追求渲染效率,桌面程式則關註記憶體消耗以及界面載入效率和流暢性。當我們需要進行性能優化時,首先需要找到性能瓶頸。本文將介紹兩個WPF性能優化分析工具:記憶體使用率應用程式時間線的使用。

記憶體使用率

記憶體使用率是Visual Studio中集成的診斷工具之一,適用於.Net程式查找記憶體泄漏或者低效記憶體適用情況。

預設情況下,調試程式時診斷工具視窗會自動開啟停靠在右側或者底部。如果因為個人適用習慣關閉了診斷工具視窗,可以通過頂部菜單欄找到“調試”—>“視窗”—>“顯示診斷視窗”或者快捷鍵Ctrl+Alt+F2打開診斷工具視窗。

診斷工具視窗可以查看程式運行過程CPU和記憶體消耗的變化,滑鼠懸浮在進程記憶體消耗圖上時,會顯示任意時間點的記憶體消耗。

要查看記憶體使用情況時,可以在診斷工具視窗的記憶體使用情況選項卡點擊“截取快照”按鈕。通常我們會在記憶體顯著增加前後各截取一次記憶體快照,然後對比兩次快照中對象和堆大小的差異。
image

上圖中顯示了兩次截圖快照的時間、對象個數和堆中的位元組數。其中第二條快照信息中對象個數和堆大小中括弧內的數值是相對於第一條快照中的變化。對象個數和堆大小這兩列中的數值是以超鏈接形式顯示,點擊後可以打開選定快照的堆視圖。顯示了快照捕獲的完整的對象集,包括了各類型對象的個數,對象實例大小和非獨占大小。點擊表頭可以對選定列進行排序。
image

並且可以通過堆視圖左上角類型篩選器快速查找指定類型的記憶體信息。下圖中顯示記憶體中增加了1800個Student對象實例,占用大約158KB記憶體。
image

應用程式時間線

應用程式時間線工具集成在Visual Studio中的性能探測器中,用於查找XAML應用程式交互相關的性能問題。該工具提供了詳細的視圖顯示XAML應用程式(目前不支持Avalonia)資源使用情況,可以查看UI線程使用率,可視化吞吐量,UI元素解析、佈局及呈現、網路及磁碟I/O所耗費的時間。

使用應用程式時間線工具時,只需單擊“調試”—>“性能探測器”或者使用快捷鍵Alt+F2,在“XXX.diagsession 視窗”中看到分析工具。勾選應用程式時間線後點擊“開始”按鈕進行性能數據收集。需要停止分析時,點擊分析視窗左上角的“停止收集”按鈕,等待一會兒就會生成詳細的視圖。在診斷會話視窗的分析工具列表中有個“記憶體使用率”,勾選後也可以分析記憶體使用情況(上一小節已詳細介紹)。
image

UI線程使用率

UI線程使用率以柱狀圖的形式呈現每個時間點UI線程使用情況,並用不同色塊區分ui元素解析、佈局、呈現、I/O、應用程式代碼、Xaml其他使用UI線程的占比。UI線程使用率過高的時間點可能表示應用程式響應能力較差,是性能優化需要關註的地方。
image

可視吞吐量(FPS)

“可視吞吐量(FPS)” 折線圖顯示了應用程式的 UI線程和複合線程上的每秒幀數 (FPS),較低的幀速率也意味著應用程式響應能力較差。
image

時間線詳細信息

時間線詳細信息視圖呈現了每個時間點占用CPU的UI框架子系統和系統組件以及它們占用時間。
主要包括以下幾類:

  • 解析:分析XAML文件並創建對象或者元素所消耗的時間。
  • 佈局:計算所有需要佈局的元素的大小和位置耗用的時間(即在ArrangeMeasureApplyTemplateArrangeOverrideMeasureOverride中所用的時間)。在大型應用程式中,可能會同時在屏幕上顯示數千個元素。此顯示可能會導致UI幀速率降低以及應用程式響應能力相應地變差。
  • 呈現:在屏幕上繪製XAML元素所耗用的時間。
  • I/O:從本地磁碟或從通過Microsoft Windows Internet (WinINet) API訪問的網路資源中檢索數據所耗用的時間。
  • 應用程式代碼:執行與分析或佈局無關的應用程式(用戶)代碼所耗用的時間。
  • Xaml其他:執行 XAML 運行時代碼所耗用的時間。

時間線詳細信息視圖分為左中右三列。左側顯示事件名稱,絕大部分事件是發生在UI線程上,這些事件名稱前有一個紫色線條標記,非UI線程上的事件則無標記。中間一列頂部顯示時間軸,下邊顯示每個事件的色塊標記(與UI線程使用率中色塊顏色一致)、持續總計時間(自身和子元素持續時間的總和)和自身持續時間,滑鼠懸浮在元素上會顯示自身持續時間和事件開始時間。右側一列則顯示選中事件的詳細信息描述。
image

上邊示例中,UI線程使用率過高,耗時最長的是佈局,開始於6.91秒,總耗時6.56秒,涉及33237個元素,其原因就是TreeView沒有開啟虛擬化,一次性把所有的數據都渲染出來,導致UI響應差。通過這個分析找到性能瓶頸,就可以有的放矢進行優化。這裡只需開啟虛擬化即可,現實開發中導致性能瓶頸的原因多種多樣,需結合實際情況優化解決。

小結

記憶體使用率應用程式時間線是WPF開發過程中不可或缺的兩個有效工具,此外,Snoop以及Visual Studio中的實時可視化樹、實時屬性資源管理器、XAML實時預覽、XAML綁定失敗、輔助功能檢查等工具也能提高開發調試效率。

參考

https://devblogs.microsoft.com/visualstudio/analyze-cpu-memory-while-debugging/
https://learn.microsoft.com/zh-cn/visualstudio/profiling/application-timeline?view=vs-2022


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 1.標準庫參考:shutil.rmtree。 根據設計,rmtree在包含只讀文件的文件夾樹上失敗。如果要刪除文件夾,不管它是否包含只讀文件,請使用 import shutil shutil.rmtree('/folder_name', ignore_errors=True) 2.從os.walk( ...
  • 在原文上有刪減,原文鏈接Rust 的面向對象特性。 目錄面向對象語言的特征對象包含數據和行為封裝隱藏了實現細節繼承,作為類型系統與代碼共用顧及不同類型值的 trait 對象定義通用行為的 trait實現 traittrait 對象執行動態分發麵向對象設計模式的實現定義 Post 並新建一個草案狀態的 ...
  • 一、測試運行python項目 1.1 Flask項目 說明1:當我們直接用編譯器運行Flask項目的時候,會有一個提示:意思就是:這是開發環境的伺服器,不能用於生產環境的部署,請使用WSGI的伺服器替換 1.2 Django項目 說明2:當我們直接用編譯器運行Django項目的時候,同樣有個提示,這 ...
  • 前置知識 首先給出堆的定義: 堆是一顆樹,滿足堆的性質,即: 對於一個節點,它的權值大於(或小於)它的各個兒子的權值 有這個性質,顯然 堆的根節點權值是整個堆中最大或最小的 由此可分為小根堆和大根堆 二叉堆 最常見的堆就是二叉堆 二叉堆是一顆滿足堆的性質的完全二叉樹 顯然,二叉堆的子樹也是二叉堆 接 ...
  • mysql在windows下配置root用戶遠程訪問 1,管理員打開CMD 2,cd到mysql的bin cd C:\Program Files\MySQL\MySQL Server 8.0\bin 3,登錄mysql mysql -u root -p 4,執行sql查看當前用戶 use mysql ...
  • 異常 本來 springboot 配置 mysql 配置正常,後來新加入了其他數據源,發現報錯: org.apache.ibatis.binding.BindingException: Invalid bound statement (not found) 解決方案 多數據源配置下,解決 org.a ...
  • std::borrow::ToOwned是Rust標準庫中的一個特征,用於從借用的數據中創建一個具有所有權的副本。它的作用和Clone是一樣的,但是相比Clone,它支持泛型;也就是說我們可以將一個類型T“Clone”為另一個類型U。這對處理一些特殊的類型來說很有用。 ToOwned的簽名 ToOw ...
  • 1引言 在實際的應用中,我們經常需要調用第三方API來獲取數據或執行某些操作。然而,由於網路不穩定、第三方服務異常等原因,API調用可能會失敗。為了提高系統的穩定性和可靠性,我們通常會考慮實現重試機制。 本文將深入探討如何在Spring Boot項目中優雅地重試調用第三方API,並結合代碼示例,展示 ...
一周排行
    -Advertisement-
    Play Games
  • 1、預覽地址:http://139.155.137.144:9012 2、qq群:801913255 一、前言 隨著網路的發展,企業對於信息系統數據的保密工作愈發重視,不同身份、角色對於數據的訪問許可權都應該大相徑庭。 列如 1、不同登錄人員對一個數據列表的可見度是不一樣的,如數據列、數據行、數據按鈕 ...
  • 前言 上一篇文章寫瞭如何使用RabbitMQ做個簡單的發送郵件項目,然後評論也是比較多,也是準備去學習一下如何確保RabbitMQ的消息可靠性,但是由於時間原因,先來說說設計模式中的簡單工廠模式吧! 在瞭解簡單工廠模式之前,我們要知道C#是一款面向對象的高級程式語言。它有3大特性,封裝、繼承、多態。 ...
  • Nodify學習 一:介紹與使用 - 可樂_加冰 - 博客園 (cnblogs.com) Nodify學習 二:添加節點 - 可樂_加冰 - 博客園 (cnblogs.com) 介紹 Nodify是一個WPF基於節點的編輯器控制項,其中包含一系列節點、連接和連接器組件,旨在簡化構建基於節點的工具的過程 ...
  • 創建一個webapi項目做測試使用。 創建新控制器,搭建一個基礎框架,包括獲取當天日期、wiki的請求地址等 創建一個Http請求幫助類以及方法,用於獲取指定URL的信息 使用http請求訪問指定url,先運行一下,看看返回的內容。內容如圖右邊所示,實際上是一個Json數據。我們主要解析 大事記 部 ...
  • 最近在不少自媒體上看到有關.NET與C#的資訊與評價,感覺大家對.NET與C#還是不太瞭解,尤其是對2016年6月發佈的跨平臺.NET Core 1.0,更是知之甚少。在考慮一番之後,還是決定寫點東西總結一下,也回顧一下.NET的發展歷史。 首先,你沒看錯,.NET是跨平臺的,可以在Windows、 ...
  • Nodify學習 一:介紹與使用 - 可樂_加冰 - 博客園 (cnblogs.com) Nodify學習 二:添加節點 - 可樂_加冰 - 博客園 (cnblogs.com) 添加節點(nodes) 通過上一篇我們已經創建好了編輯器實例現在我們為編輯器添加一個節點 添加model和viewmode ...
  • 前言 資料庫併發,數據審計和軟刪除一直是數據持久化方面的經典問題。早些時候,這些工作需要手寫複雜的SQL或者通過存儲過程和觸發器實現。手寫複雜SQL對軟體可維護性構成了相當大的挑戰,隨著SQL字數的變多,用到的嵌套和複雜語法增加,可讀性和可維護性的難度是幾何級暴漲。因此如何在實現功能的同時控制這些S ...
  • 類型檢查和轉換:當你需要檢查對象是否為特定類型,並且希望在同一時間內將其轉換為那個類型時,模式匹配提供了一種更簡潔的方式來完成這一任務,避免了使用傳統的as和is操作符後還需要進行額外的null檢查。 複雜條件邏輯:在處理複雜的條件邏輯時,特別是涉及到多個條件和類型的情況下,使用模式匹配可以使代碼更 ...
  • 在日常開發中,我們經常需要和文件打交道,特別是桌面開發,有時候就會需要載入大批量的文件,而且可能還會存在部分文件缺失的情況,那麼如何才能快速的判斷文件是否存在呢?如果處理不當的,且文件數量比較多的時候,可能會造成卡頓等情況,進而影響程式的使用體驗。今天就以一個簡單的小例子,簡述兩種不同的判斷文件是否... ...
  • 前言 資料庫併發,數據審計和軟刪除一直是數據持久化方面的經典問題。早些時候,這些工作需要手寫複雜的SQL或者通過存儲過程和觸發器實現。手寫複雜SQL對軟體可維護性構成了相當大的挑戰,隨著SQL字數的變多,用到的嵌套和複雜語法增加,可讀性和可維護性的難度是幾何級暴漲。因此如何在實現功能的同時控制這些S ...