获取高精度的时间差,可以用来分析页面运行时间的长短

[ 2005-06-15 15:24:36 | 作者: admin ]
字号: | |
DateTime.Now的精度是很低,这个低的意思是,两次获取的DateTime.Now的Ticks的差,只是一个较大数的整数倍。例如在我的机器上,这个差最小是10.114ms。所以,如果我用DateTime.Now来计算时间差,那么就无法精确到10ms以内。

后来发现ASP.NET的TRACE的精度很高,用Reflector看它的实现,发现了它是使用这两个方法的:

参考MSDN:How To: Time Managed Code Using QueryPerformanceCounter and QueryPerformanceFrequency

我自己了按照这个写了个类,代码如下
using System;
using System.Runtime.InteropServices;
public class A
{
        [DllImport("kernel32.dll")]
        static extern bool QueryPerformanceCounter([In, Out] ref long lpPerformanceCount);
        [DllImport("kernel32.dll")]
        static extern bool QueryPerformanceFrequency([In, Out] ref long lpFrequency);

        static long _f = 0;

        static public long GetTickCount()
        {
               long f = _f;

               if (f == 0)
               {
                    if (QueryPerformanceFrequency(ref f))
                    {
                    _f = f;
                    }
                    else
                    {
                    _f = -1;
                    }
               }
               if (f == -1)
               {
                    return Environment.TickCount * 10000;
               }
               long c = 0;
               QueryPerformanceCounter(ref c);
               return (long)(((double)c) * 1000 * 10000 / ((double)f));
        }

        //GetTickCount()为0时的DateTime.Ticks值
        static long _tc = 0;

        //这个返回的不是真正的精确时间,但时间与时间的差是精确的。
        //GetExactNow与DateTime.Now的偏差比DateTime.Now的精度还要小,所以该偏差
        static public DateTime GetExactNow()
        {
               if (_tc == 0)
               {
                    long tc = GetTickCount();
                    DateTime dt = DateTime.Now;
                    _tc = dt.Ticks - tc;
                    return dt;
               }

               return new DateTime(_tc + GetTickCount());
        }
}


在ASP。NET的应用,可以在Global.asax的Application_BeginRequest事件中加入代码来纪录程序开始时的TickCount:

Context.Items["BeginRequestTickCount"]=A.GetTickCount();

然后在页面输出的后面:

<html>....
<div align="center">
<%=new TimeSpan(A.GetTickCount()-(long)Context.Items["BeginRequestTickCount"]).TotalMilliseconds%>
</div>
</body></html>


这样就可以达到获取页面运行时间值了。(当然输出TotalMilliseconds后Asp.Net还要一些后期工作的,不过这个时间应该只需要0.n ms)
评论Feed 评论Feed: http://blog.xg98.com/feed.asp?q=comment&id=120

这篇日志没有评论。

此日志不可发表评论。