gpt4 book ai didi

c++ - 了解基本代码分析

转载 作者:太空宇宙 更新时间:2023-11-04 11:41:10 24 4
gpt4 key购买 nike

我正在尝试学习分析并遵循此 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;
}

我得到了以下结果

enter image description here

enter image description here

根据指南,高独占计数可能表明函数本身存在性能瓶颈。

似乎 [apphelp.dll][ntdll.dll] 存在基于高独占计数的性能瓶颈。

这些是我的以下问题,我对文章的理解有问题

1) 70% 的包容性样本是什么意思??是不是说70%的时间都花在了这个功能上。这有什么意义??

2) exclusive sample 是 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 changes everytime i generate a new report with the same代码集

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

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

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

最佳答案

我的理解:

1) inclusive 表示在这个函数中花费的时间包括你在这个函数中调用的函数花费的时间。例如: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 << add (2,3)”由程序集为“cout << 5”

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

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

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

8) 同上。

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

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

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

关于c++ - 了解基本代码分析,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/21367302/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com