C++(Qt)软件调试---Windows 性能分析器WPA(28)

C++(Qt)软件调试---Windows 性能分析器WPA(28)


### 文章目录

  • [C++(Qt)软件调试---Windows 性能分析器WPA(28)](#文章目录 C++(Qt)软件调试---Windows 性能分析器WPA(28) @[toc] 1 概述🐜 2 环境准备 3 程序性能分析 4 相关地址🐐)
  • [@[toc]](#文章目录 C++(Qt)软件调试---Windows 性能分析器WPA(28) @[toc] 1 概述🐜 2 环境准备 3 程序性能分析 4 相关地址🐐)
  • [1 概述🐜](#文章目录 C++(Qt)软件调试---Windows 性能分析器WPA(28) @[toc] 1 概述🐜 2 环境准备 3 程序性能分析 4 相关地址🐐)
  • [2 环境准备](#文章目录 C++(Qt)软件调试---Windows 性能分析器WPA(28) @[toc] 1 概述🐜 2 环境准备 3 程序性能分析 4 相关地址🐐)
  • [3 程序性能分析](#文章目录 C++(Qt)软件调试---Windows 性能分析器WPA(28) @[toc] 1 概述🐜 2 环境准备 3 程序性能分析 4 相关地址🐐)
  • [4 相关地址🐐](#文章目录 C++(Qt)软件调试---Windows 性能分析器WPA(28) @[toc] 1 概述🐜 2 环境准备 3 程序性能分析 4 相关地址🐐)
更多精彩内容
👉内容导航 👈
👉C++软件调试 👈

1 概述🐜

软件开发中程序性能优化、性能瓶颈排查对开发人员来说是必不可少的技能。

常见的性能优化包括CPU使用率、内存使用率、内存泄漏、文件IO等。

linux下的perf工具功能非常强大,但是可惜不支持Windows;而windows中VS也提供了类似的工具(性能探查器),windows除了vs自带的性能探查器外,还有更强大的WPA、WPR、xperf可用于性能分析。

  • 可以使用xperf命令行工具或者WPR图形界面工具保存系统和应用程序事件到文件;
  • 然后使用图形界面的WPA进行分析;
  • WPA支持火焰图等多种图表分析;
  • WPA支持随时启动记录和停止记录,不需要像其它分析工具在程序启动时运行;
  • 并且WPA支持同时记录系统的和所有正在运行的进程的信息。
  • 本文中只演示如何使用WPA进行CPU性能分析,还有更多强大功能没有演示。

演示环境:

环境 版本
系统 Windows11
编译器 msvc2017/2022 由于WPA需要pdb符号表,所以如果是mingw编译器生成的程序需要使用cv2pdb工具转换。

2 环境准备

  1. 安装VS时Windows SDK中就包含了WPA分析工具;

  2. 或者单独下载安装进行安装;

  3. 可选择直接安装或者下载离线安装包;

  4. 安装完成后如下图所示。

3 程序性能分析

  1. 创建一个工程,这里我创建的是一个Qt工程;

  2. 添加如下所示代码:

    cpp 复制代码
    #include "widget.h"
    #include "ui_widget.h"
    
    #include <vector>
    #include <list>
    
    using namespace std;
    
    void fun1()
    {
        vector<int> arr;
        for (int i = 0; i < 10000000; i++)
        {
            arr.push_back(i);
        }
    }
    
    void fun2()
    {
        list<int> arr;
        for (int i = 0; i < 10000000; i++)
        {
            arr.push_back(i);
        }
    }
    void fun3()
    {
        vector<int> arr;
        arr.reserve(10000000);
        for (int i = 0; i < 10000000; i++)
        {
            arr.push_back(i);
        }
    }
    
    Widget::Widget(QWidget *parent)
        : QWidget(parent)
        , ui(new Ui::Widget)
    {
        ui->setupUi(this);
    }
    
    Widget::~Widget()
    {
        delete ui;
    }
    
    void Widget::on_pushButton_clicked()
    {
        fun1();
        fun2();
        fun3();
    }
  3. 编译启动程序后,运行WPR UI程序,如下图所示,然后点击【Start】开始记录;

  4. 记录完成后再次点击【Save】,如下所示保存记录信息到文件中。

  5. 启动WPA程序;

  6. 打开刚才保存的文件;

  1. 如下图所示,打开【Computation】【CPU Usage(Sampled)】【Utilization by COFF Group,Module, Function】;

  2. 打开后如下图所示,会显示所有程序的火焰图;

  3. 然后按快捷键【Ctrl + F】打开搜索窗口,选择【Process】,然后输入需要查找的程序名称;

  4. 找到需要分析的程序后,鼠标右键选择【Filter To Selection】;

  1. 这样就只会显示选中程序的火焰图了。

  2. 然后选择【Configure Symbol Paths】设置pdb符号表路径,选择【Load Symbols】加载符号表;

  3. 加载完成符号表后就可以如下所示查看具体函数的性能情况了。

  4. 可以在火焰图窗口上方直接搜索具体的函数名称;

  5. 或者可以打开搜索窗口,选择【Stack】查找具体的函数名称。

  1. 当火焰图过大时,看不清楚,可以选择行,然后鼠标右键设置【Filer To Flame】显示选中行往上的火焰图,或者设置【Undo Filer】取消。

  2. 注意:如果勾选了下图中的【Filter Lower Values】会对设置【Filer To Flame】的精确度有影响。

  3. 如果加载符号表时非常慢,可能是在联网下载符号表,可以选择关闭网络获取取消勾选下载符号表;

4 相关地址🐐

相关推荐
fqbqrr12 分钟前
2601C++,编写自己模块
c++
王老邪1 小时前
Windows下利用PowerShell实现Git自动推送
windows·git
王老师青少年编程3 小时前
2025年12月GESP真题及题解(C++七级): 城市规划
c++·gesp·csp·信奥赛·七级·csp-s·提高组
寻星探路4 小时前
【算法专题】滑动窗口:从“无重复字符”到“字母异位词”的深度剖析
java·开发语言·c++·人工智能·python·算法·ai
我叫袁小陌5 小时前
C++多线程全面详解
开发语言·c++
m0_748250036 小时前
C++ 官方文档与标准
开发语言·c++
matlabgoodboy6 小时前
程序代做python代编程matlab定制代码编写C++代写plc设计java帮做
c++·python·matlab
DYS_房东的猫6 小时前
《 C++ 零基础入门教程》第6章:模板与 STL 算法 —— 写一次,用万次
开发语言·c++·算法
点云SLAM7 小时前
C++ 静态初始化顺序问题(SIOF)和SLAM / ROS 工程实战问题
开发语言·c++·slam·静态初始化顺序问题·工程实战技术·c++static 关键字
pen-ai7 小时前
打通 Python 与 C++ 的参数传递机制
开发语言·c++·python