您的位置:首页 > 其它

关于VisualStudio性能分析数据中的独占样本数和非独占样本数的意义

2014-02-22 10:15 375 查看

关于VisualStudio性能分析数据中的独占样本数和非独占样本数的意义

转自http://www.cnblogs.com/TianFang/archive/2012/11/18/2776266.html

VisualStudio中自带有Profile工具进行性能性能分析,其中用得比较多的数据是函数调用时间,它主要有独占样本数和非独占样本数两个指标,关于这两个指标代表的意义,MSDN的解释比较文艺:

非独占样本数:
为函数收集的性能数据的总数,其中包括该函数调用的其他函数的性能数据。

非独占转换次数:
在此函数(包括此函数调用的函数)的所有实例中发生操作系统(转换)事件的次数。

其它性能数据解释可以参看:http://msdn.microsoft.com/zh-cn/library/ms242747(v=vs.90).aspx

当然,就算看不懂两个数据表示的具体意义也无碍于我们分析性能瓶颈,反正数值大的肯定是性能瓶颈。不过,为了更好的使用这个工具,还是稍微理解点的好。

为了通俗的解释这两个指标,我这里写了两个简单的函数Foo1和Foo2,其中Foo1调用了Foo2,其它的函数体是一样的。

    staticvoid Foo1()

    {

        var total = 0;

        for (int i = 0; i < 10000 * 10000; i++)

        {

            total += i;

        }

        Foo2();

    }

    staticvoid Foo2()

    {

        var total = 0;

        for (int i = 0; i < 10000 * 10000; i++)

        {

            total += i;

        }

    }

我们的调用方式如下:

    staticvoid Main(string[]
args)

    {

        System.Threading.Thread.Sleep(2000);        //等待采集器启动需要一段时间
        Foo1();

    }

此时生成的性能报告如下:

函数名
非独占样本数
独占样本数
非独占样本数百分比
独占样本数百分比
ConsoleApplication1.Program.Foo1

526
289
99.81
54.84
ConsoleApplication1.Program.Foo2

237
237
44.97
44.97
对于Foo2,它的独占样本数和非独占样本数是一样的;而对于Foo1它的非独占样本数是独占样本数的两倍。

从中可以看出:

非独占样本数是指的包括了子函数执行时间的总执行时间

独占样本数是不包括子函数执行时间的函数体执行时间

如果把Main函数的采集数据放在一起就更容易理解了:Main函数独占样本数百分比为0,因为它的函数体执行时间几乎忽略不计,而非独占样本数百分比为100%,因为它在整个进程的生命周期内都存在。

函数名
非独占样本数
独占样本数
非独占样本数百分比
独占样本数百分比
ConsoleApplication1.Program.Foo1

526
289
99.81
54.84
ConsoleApplication1.Program.Foo2

237
237
44.97
44.97
ConsoleApplication1.Program.Main

527
0
100
0
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: