【问题标题】:Understanding basic code profiling了解基本代码分析
【发布时间】: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) 为什么GraphHot PathFunction doing the most individual work 每次使用相同的代码集生成新报告时都会发生变化

7) 我应该如何找到我的应用程序中的性能瓶颈并对其进行优化??

8) 为什么像_mainCRTStartup,[kernel32.dll]这样的函数有0%的独占样本,这是什么意思??

请原谅我问这样的新手问题,我是代码分析新手

【问题讨论】:

  • 这个问题似乎跑题了,因为它不是在寻求代码审查,而是在询问如何使用工具。
  • 无论做什么,不要关注专属时间。相反,请查看包容性时间。原因 - 包含时间包括独占时间,此外还包括在从属呼叫中花费的时间。在“真正的”软件中,程序可能很慢,要么是因为它们有很多独占时间,要么是因为它们发出的从属调用超出了它们的需要。包容性时间抓住了这两者。示例:当答案很明显“不要这么多内存分配”时,人们可以查看独占时间并询问“我怎样才能加快内存分配”。

标签: c++ optimization performance refactoring visual-studio


【解决方案1】:

我的理解:

1) 包括在这个函数中花费的时间,包括在这个函数中调用的函数中花费的时间。例如:inclusive(main) 包含 add 所用的时间,exclusive(main) 不包含。

2) 检查http://en.wikipedia.org/wiki/Microsoft_Windows_library_files#NTDLL.DLL 你的代码基本上什么都不做。你的大部分时间都花在系统暂停上......你的代码执行 1 几纳秒,然后你需要一些时间来按返回

3) 是cpu使用百分比。超过 100 个时钟周期,操作系统分配给您的程序有多少?

4) 不确定,它可能已被内联...如果您使用 /Fa 开关来获取程序集,并打开优化 ( O2 ),您可能会看到编译器翻译了“cout

5) 您正在使用 system("pause") 和 cout。那些将调用 windows dll(你的 os api)

6) 对于图表:您的 CPU 是否在做其他事情?您在分析时使用其他应用程序吗? 对于另外两个:关闭系统(“暂停”)并检查它是否仍然改变

7) 你走对了,但是这段代码什么也没做,所以你的应用程序在系统 dll 中花费的时间比你的代码更多:)

8) 同上。

尝试一个真正做某事的测试函数,比如一个带有指针比较的排序函数和你自己的交换函数。您在 swap() compare(..) 和 sort(..) 函数上花费了多少独占时间?

试试这样的代码: http://www.ousob.com/ng/turboc/ng4686d.php

并比较一些糟糕的对象,也许使用带有深层复制的讨厌的交换功能。我发誓你会真正看到一些东西。

【讨论】:

    猜你喜欢
    • 2019-07-24
    • 2017-05-14
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2016-05-17
    相关资源
    最近更新 更多