日期:2014-05-20  浏览次数:20460 次

请教老孟,页面执行时间的问题.
今天在老孟的页面上查了个东西,偶然中发现了很久以前自己遇到的一个问题,至今未解决.在老孟的页面上用到了这个东东,想知道是怎么实现的.

页面地址:http://dotnet.aspx.cc/SearchDoc.aspx
那个页面用时是怎么得出来的?

不胜感激.



------解决方案--------------------
用PerformanceCounter

从网上搜的:


获取高精度的时间差,可以用来分析页面运行时间的长短
Author:lostinet
From: joycode
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)