Visual Studio分析器使用大量的RAM
Visual Studio profiler uses huge amount of RAM
我正在尝试做一个相当大的项目(在整个解决方案中大约有40000个源文件,但在分析下的项目大约有200个源文件)的仪器分析,用c++编写。
每次我运行分析时,它都会创建一个大约34GB的大报告,然后,当它要分析它时,它试图(我认为)将整个文件加载到RAM中。
显然,它使计算机无法使用,我必须在分析器完成之前停止它。
有什么建议吗?
你好,希望这个回复不会太晚。我是Visual Studio分析器团队的Andre Hamilton。分析如此大的报告文件确实需要一些时间。插装会产生这么多数据,因为您的所有函数都是插装的。如果您不介意通过命令行进行分析,那么通过检测一些函数或特定的二进制文件可以加快速度。这将生成一个vsp文件,然后你可以在VS中打开它并像往常一样使用。假设您的项目需要运行n个二进制文件。让我们假设您对这些二进制文件ni
的性能感兴趣打开VisualStudio命令提示符1)执行vsinstr ni.dll
来检测整个二进制文件,或者使用vsinstr的/include或/exclude选项来进一步限制哪些函数被检测。注意:如果您的二进制文件已被签名,则需要在插入
2)通过给定的命令在检测模式下启动分析器vsperf /start:trace /output:myinstrumentedtrace.vsp
4)当您准备停止分析时vsperf /shutdown
希望有帮助
(注意,我假设您有一个许可的VS副本来收集和分析数据)。
在分析大型或"密集"程序时,这是一个普遍的问题。您需要限制分析器仅从代码库的某些单元收集数据。在微软的分析器中,这是通过在命令行或IDE中使用包括/排除开关来完成的。
VS有一个bug,原因是大部分的分析工作是在UI线程中完成的,这使得VS无法使用,如http://channel9.msdn.com/Forums/TechOff/260091-Visual-Studio-Performance-Analysis-in-10-minutes
所述你可以尝试VS 2012,看看问题是否得到解决,但毫无疑问,加载一个34 GB的文件并不是一个简单的任务,这也是导致系统不可用的原因,所以正如约翰在评论部分上面建议的那样,把你的代码分解成更小的组件,然后做分析,希望它能帮助!
- Visual Studio 2015:Extern "C" 和 "export" 关键字
- 为cl.exe(Visual Studio代码)指定命令行C++版本
- 如何加载(或映射)文件部分的最大大小,但适合在Windows上的RAM
- 试图在visual studio上用C++创建一个桌面应用程序
- 如何在MS Visual Studio 2019中运行QT UI
- 如何使用Visual Studio 2017在C++中为参数化对象数组使用唯一指针
- Visual Studio Code - C++ Debugger 無法啟動
- Visual Studio 2019:插入多个C++风格的单行注释
- Visual Studio Code "undefined reference to `WinMain@16'"
- Visual studio代码重构似乎不起作用(例如,重命名符号-f2)
- Visual Studio中的函数声明和函数定义问题
- 如何指定我希望我的LIB链接到的DLL文件?-Visual Studio 2019
- Visual Studio mkl_link_tool.exe链接错误
- Visual Studio(或任何其他工具)能否将地址解释为调用堆栈(boost上下文)的开头
- 不同的Visual Studio版本中缺少.dll
- 用Visual Studio在C++中嵌入Julia
- Visual Studio 2017循环自动向量化问题
- 有没有办法在远程设备上打开和编辑visual Studio 2017解决方案
- 尝试使用继承和模板实现CRTP.Visual Studio正在生成编译器错误
- Visual Studio分析器使用大量的RAM