我正在尝试使用 Visual Studio 性能分析器分析我的程序,但我是这个工具的新手。
如果我在分析器中启动我的程序,我会得到一份报告,其中我看到一个函数所花费的总分析时间的百分比。但总时间可能在 5 秒到 500 秒之间变化,那么我如何查看我的优化是否有任何效果?
如果以毫秒为单位,我就不会有这个问题,但是我找不到任何像“以毫秒为单位显示”或类似的功能。有这样的功能吗?
最佳答案
Visual Studio Profiler 中有两种不同的 CPU 分析方法:Sampling 和 Instrumentation。
采样(默认)
采样分析方法以设定的时间间隔中断计算机处理器并收集函数调用堆栈。正在执行的函数的独占样本计数增加,调用堆栈上所有调用函数的包含计数增加。采样报告显示分析模块、函数、源代码行和指令的这些计数的总和。
采样方法是轻量级的(您的二进制文件没有变化)并且对应用程序方法的执行几乎没有影响:它收集仅统计有关应用程序在一个过程中执行的工作的统计数据分析 session 。
这对初步探索很有帮助。高 % 可能意味着函数速度慢或函数调用过于频繁。
仪器仪表
仪器分析方法收集分析应用程序中函数调用的详细时间。如何?它注入(inject)代码,捕获检测文件中每个函数的计时信息以及这些函数进行的每个函数调用。 Instrumentation 还可以识别函数何时调用操作以执行诸如写入文件之类的操作。
在报告中,您将看到应用程序时间(执行一段代码所花费的总时间,但不包括调用操作系统、ado.net、服务调用等所花费的时间)和运行时间(执行一段代码所花费的总时间)。
这种分析模式也有更高的运行时开销。这不可避免地会稍微改变您的应用程序的性能特征,但影响很小。
只有这个选项可以让你看到毫秒。因此,在性能资源管理器的向导中更改分析方法。另请注意,此选项有时不可用,例如在分析单元测试时。
关于c# - 如何在 Visual Studio Performance Analyzer 中查看毫秒而不是样本百分比,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/17362448/