虚拟主机行业最新资讯 虚拟主机评测对比 互联网最新动态 技术学院 站长资讯 在线教程 网站运营
搜索优化 服务器 网络编程 图形图象 站长之家 网页制作 操作系统
冲浪宝典 软件教学 视频通信 办公软件 邮件系统 网络安全 认证考试
您当前位置:站长资讯>-> 网站运营-> 网站运营
获取高精度的时间差,可以用来分析页面运行时间的长短-.NET教程,Asp.Net开发
作者:网友供稿 点击:130
  西部数码-全国虚拟主机10强!20余项虚拟主机管理功能,全国领先!第6代双线路虚拟主机,南北访问畅通无阻!虚拟主机可在线rar解压,自动数据恢复设置虚拟目录等.虚拟主机免费赠送访问统计,企业邮局.Cn域名注册10元/年,空间150元起,免费试用7天,满意再付款!P4主机租用799元/月.月付免压金!
文章页数:[1] 

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


文章整理:西部数码--专业提供域名注册虚拟主机服务
http://www.west263.com
以上信息与文章正文是不可分割的一部分,如果您要转载本文章,请保留以上信息,谢谢!
文章页数:[1] 
相关主题
Google

热门文章
·ASP.NET的安装与运行环境-.NET教程,Asp.Net开发
·运用.NET+SQL Server2005构建多层网站(3)-.NET教程,数据库应用
·JAVA写的四则混合运算-JSP教程,Java技巧及代码
·获取高精度的时间差,可以用来分析页面运行时间的长短-.NET教程,Asp.Net开发
·基于.Net平台应用程序唯一运行实例C#代码实现-.NET教程,C#语言
·Alexa 世界网站排名研究(下)-网站运营,搜索引擎推广
·运用.NET+SQL Server2005构建多层网站(1)-.NET教程,数据库应用
·优化系统让Photoshop运行更流畅-网页设计,Photoshop
·ASP.NET 2.0运行时简要分析-.NET教程,Asp.Net开发
·手工打造运算符重载过程-.NET教程,C#语言

最新文章
·MySQL服务器内部安全数据目录访问
·MySQL和SQL Server,到底选择谁?
·五种推广模式的优劣的比较
·基于.Net平台应用程序唯一运行实例C#代码实现-.NET教程,C#语言
·运用反射给实体赋值-.NET教程,Asp.Net开发
·大数运算(一)-.NET教程,评论及其它
·虚拟主机上asp.net运行权限不足问题及解决-.NET教程,Asp.Net开发
·ASP.NET底层架构探索之进入.NET运行时-.NET教程,Asp.Net开发
·基于.Net平台应用程序唯一运行实例实现-.NET教程,.NET Framework
·ASP.NET 2.0运行时简要分析-.NET教程,Asp.Net开发

相关主题



友情链接
CNNIC 西部数码
万网 自助建站
虚拟主机 asp空间
域名注册 域名
域名申请 主页空间
论坛空间 网站空间
国际域名 虚拟空间
空间租用 DDOS防火墙
成都主机托管 四川主机托管
主机租用 服务器租用
网站目录 一班在线
虚拟主机 网址大全
软件下载
自助链接
虚拟主机资讯 特价虚拟主机


版权申明:本站文章均来自网络,如有侵权,请联系我们,我们收到后立即删除,谢谢!

特别注意:本站所有转载文章言论不代表本站观点,本站所提供的摄影照片,插画,设计作品,如需使用,请与原作者联系,版权归原作者所有。
  打印  刷新  关闭


联系我们  |  广告服务  |  免责声明  |  友情连接
Copyright ?2005 - 2006 All Rights Reserved
蜀ICP备05000045号