【发布时间】:2014-01-27 02:15:22
【问题描述】:
我正在尝试了解分析并遵循此guide,因此我尝试在 Windows 7 上的 MS VS 2010 上分析以下代码。我不确定这是不是问这个问题的正确地方
#include <iostream>
using namespace std;
int add(int,int);
int main()
{
int x [100];
for (int i=0;i<100;i++)
{
x[i]=i;
}
cout<<add(2,3);
system("PAUSE");
}
int add (int x, int y)
{
return x+y;
}
我得到了以下结果
根据指南,High exclusive counts may indicate a performance bottleneck within the function itself.
似乎[apphelp.dll] 和[ntdll.dll] 存在基于高独占计数的性能瓶颈。
这些是我的以下问题,我对文章的理解有问题
1) 70% 的包容性样本是什么意思?这是否意味着 70% 的时间都花在了这个功能上。这有什么意义??
2) 30% 或 0% 的独家样本均值是什么意思?这有什么意义??
3) 对于图表,X 轴是挂钟时间,Y 轴呢?它有什么意义
4) 我创建了一个函数:add(int x , int y ),它在配置文件报告中的什么位置??
5) [apphelp.dll] 和 [ntdll.dll] 到底是什么?我知道它们是动态链接库,但为什么将其置于函数之下。我的代码中没有看到这样的函数
6) 为什么Graph、Hot Path、Function doing the most individual work 每次使用相同的代码集生成新报告时都会发生变化
7) 我应该如何找到我的应用程序中的性能瓶颈并对其进行优化??
8) 为什么像_mainCRTStartup,[kernel32.dll]这样的函数有0%的独占样本,这是什么意思??
请原谅我问这样的新手问题,我是代码分析新手
【问题讨论】:
-
这个问题似乎跑题了,因为它不是在寻求代码审查,而是在询问如何使用工具。
-
无论做什么,不要关注专属时间。相反,请查看包容性时间。原因 - 包含时间包括独占时间,此外还包括在从属呼叫中花费的时间。在“真正的”软件中,程序可能很慢,要么是因为它们有很多独占时间,要么是因为它们发出的从属调用超出了它们的需要。包容性时间抓住了这两者。示例:当答案很明显“不要做这么多内存分配”时,人们可以查看独占时间并询问“我怎样才能加快内存分配”。
标签: c++ optimization performance refactoring visual-studio