使用Visual Studio Profiler分析程序性能

2024-02-12 09:38

本文主要是介绍使用Visual Studio Profiler分析程序性能,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

  Profiler 是 Visual Studio 中集成的性能分析工具。它主要用于分析程序中所有函数调用所占的耗费时间。它提供了Sample和Instrumentation两种检测方式,能够生成简洁易读的报告。它只适用于Team Suit版本。

   

    下面性能分析的环境是在Windows XP SP2,Visual Studio 2008 Team Suit环境。

 

    首先,打开您需要测试的程序的解决方案或项目文件,需要说明的是被测试的程序的设置。推荐您使用Debug的编译模式,如果您使用的是Release的编译模式,程序将无法分析出函数的符号。请您在VS中点击Project->Properties->Configuration Properties->Linker->Command Line,在右侧Additional options中填入/Profile,代表您告诉链接器Linker,此程序需要被用于VS Profiler。新手非常需要注意的是,当程序性能调优完成后,您需要去掉这个添加的选项,使用Release编译链接生成可以发布的程序。


    其次,请先编译链接您的程序,如果您的程序是DLL,也请准备好测试的EXE程序。在VS中点击Analyze->Lauch Performance Wizard。(当您熟练使用Profiler后,也可以使用 Analyze->Profiler->New Performance Session )在这里,请选择你想profile的目标,如果您的项目是EXE时,选择对应的项目文件即可(当然,您也可以选择Profile an executable(.EXE))。如果您的项目是DLL时,请选择Profile a dynamic link library(.DLL)。点击下一步,如果您选择的是 Profile an executable(.EXE)或者 Profile a dynamic link library(.DLL),写入您的生成的程序或者DLL,选择您的EXE测试程序。点击下一步。



    这里需要注意了,如果您的程序和IO,网络,中断等没有直接关系,并且程序需要测试的时间比较长,请选择Sample;如果您的程序和IO,网络,中断有关系时,请选择Instrumentation。点击下一步,然后点击完成。

 

“Sampling就是采样。通过在程序运行过程中暂停程序,记录堆栈中的信息,然后恢复程序来分析程序。虽然它会暂停程序, 但它的这种暂停、记录、恢复的速度是非常迅速的,相对于程序的执行时间可以忽略不计。因此这种模式对程序执行的影响其实是相对较小的。但是由于采样的时间间隔,有些小的执行迅速的函数可能被忽略,不过,如果是为了性能的提升,那些速度快的函数到并没有什么分析价值。另外一点,因为采样时间是系统的时间,在分 析过程中会受到其他程序的影响。Instrument执行过程超级缓慢。它在程序运行以前,侵入程序中,在每个函数的开头和结尾都嵌入了用于分析的宏。在执行函数的过程中记录下宏传出来的信息。Instrument的分析用了两套时间。一套和Sampling一样,使用的函数实际执行时间,叫做Application Time;另一套使用的是Profiler自行提供的时间单位,以程序执行的CPU时间片为基元计算出函数的CPU占用时间,称为Elapsed Time。你可以根据你的需要查看相应的执行时间,因为Instrument提供的Elapsed Time,你将有足够的证据证明软件缓慢速度的罪魁祸首。”(摘至《应用程序性能分析利器 —— Visual Studio Profiler》)

 

 

 

    再次,点击Performance Explorer标签栏->Launch Profiling。等待程序运行完毕后,再等待几分钟的分析,最后将生成分析报表。

 

 

 

    您可以选择按照Module或者Function的方式查看每个函数占用系统资源的数量。甚至可以查看Call Tree堆栈。

这篇关于使用Visual Studio Profiler分析程序性能的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/702289

相关文章

解决Maven项目idea找不到本地仓库jar包问题以及使用mvn install:install-file

《解决Maven项目idea找不到本地仓库jar包问题以及使用mvninstall:install-file》:本文主要介绍解决Maven项目idea找不到本地仓库jar包问题以及使用mvnin... 目录Maven项目idea找不到本地仓库jar包以及使用mvn install:install-file基

Python使用getopt处理命令行参数示例解析(最佳实践)

《Python使用getopt处理命令行参数示例解析(最佳实践)》getopt模块是Python标准库中一个简单但强大的命令行参数处理工具,它特别适合那些需要快速实现基本命令行参数解析的场景,或者需要... 目录为什么需要处理命令行参数?getopt模块基础实际应用示例与其他参数处理方式的比较常见问http

C 语言中enum枚举的定义和使用小结

《C语言中enum枚举的定义和使用小结》在C语言里,enum(枚举)是一种用户自定义的数据类型,它能够让你创建一组具名的整数常量,下面我会从定义、使用、特性等方面详细介绍enum,感兴趣的朋友一起看... 目录1、引言2、基本定义3、定义枚举变量4、自定义枚举常量的值5、枚举与switch语句结合使用6、枚

使用Python从PPT文档中提取图片和图片信息(如坐标、宽度和高度等)

《使用Python从PPT文档中提取图片和图片信息(如坐标、宽度和高度等)》PPT是一种高效的信息展示工具,广泛应用于教育、商务和设计等多个领域,PPT文档中常常包含丰富的图片内容,这些图片不仅提升了... 目录一、引言二、环境与工具三、python 提取PPT背景图片3.1 提取幻灯片背景图片3.2 提取

使用Python实现图像LBP特征提取的操作方法

《使用Python实现图像LBP特征提取的操作方法》LBP特征叫做局部二值模式,常用于纹理特征提取,并在纹理分类中具有较强的区分能力,本文给大家介绍了如何使用Python实现图像LBP特征提取的操作方... 目录一、LBP特征介绍二、LBP特征描述三、一些改进版本的LBP1.圆形LBP算子2.旋转不变的LB

Maven的使用和配置国内源的保姆级教程

《Maven的使用和配置国内源的保姆级教程》Maven是⼀个项目管理工具,基于POM(ProjectObjectModel,项目对象模型)的概念,Maven可以通过一小段描述信息来管理项目的构建,报告... 目录1. 什么是Maven?2.创建⼀个Maven项目3.Maven 核心功能4.使用Maven H

Python中__init__方法使用的深度解析

《Python中__init__方法使用的深度解析》在Python的面向对象编程(OOP)体系中,__init__方法如同建造房屋时的奠基仪式——它定义了对象诞生时的初始状态,下面我们就来深入了解下_... 目录一、__init__的基因图谱二、初始化过程的魔法时刻继承链中的初始化顺序self参数的奥秘默认

SpringBoot使用GZIP压缩反回数据问题

《SpringBoot使用GZIP压缩反回数据问题》:本文主要介绍SpringBoot使用GZIP压缩反回数据问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录SpringBoot使用GZIP压缩反回数据1、初识gzip2、gzip是什么,可以干什么?3、Spr

Spring Boot 集成 Quartz并使用Cron 表达式实现定时任务

《SpringBoot集成Quartz并使用Cron表达式实现定时任务》本篇文章介绍了如何在SpringBoot中集成Quartz进行定时任务调度,并通过Cron表达式控制任务... 目录前言1. 添加 Quartz 依赖2. 创建 Quartz 任务3. 配置 Quartz 任务调度4. 启动 Sprin

Linux下如何使用C++获取硬件信息

《Linux下如何使用C++获取硬件信息》这篇文章主要为大家详细介绍了如何使用C++实现获取CPU,主板,磁盘,BIOS信息等硬件信息,文中的示例代码讲解详细,感兴趣的小伙伴可以了解下... 目录方法获取CPU信息:读取"/proc/cpuinfo"文件获取磁盘信息:读取"/proc/diskstats"文