首 页 网络编程
网页制作 图形图象 操作系统 冲浪宝典
软件教学 认证考试

网络安全 网络办公 行业资讯 评测对比
您当前位置:站长天空 -> 网络安全-> 教你一招
获取高精度的时间差,可以用来分析页面运行时间的长短-.NET教程,Asp.Net开发
作者:网友供稿 点击:104
推荐
西部数码-全国虚拟主机10强!20余项虚拟主机管理功能,全国领先!第6代双线路虚拟主机,南北访问畅通无阻!可在线rar解压,自动数据恢复设置虚拟目录等.免费赠送访问统计,企业邮局.Cn域名注册10元/年,自助建站480元起,免费试用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.z6688.com/
以上信息与文章正文是不可分割的一部分,如果您要转载本文章,请保留以上信息,谢谢!

文章页数:[1] 


放大字体显示 缩小字体显示 打印文章 推荐给朋友
热门文章
·Java 中开源的CMS系统-JSP教程,Java技巧及代码
·ASP.NET服务器控件发送脚本-ASP教程,远程脚本
·javaCC学习笔记-JSP教程,Java技巧及代码
·asp.net中的模态对话框-ASP教程,ASP应用
·在.net应用程序中使用用户控件-.NET教程,组件控件开发
·身份证15位转换成18位代码(vbscript)-ASP教程,脚本编码
·基于dsp控制的数字式双向dc/dc变换器的实现
·利用Asp.net 动态创建DataList-ASP教程,ASP应用
·最佳的数据库分页方法-ASP教程,数据库相关
·利用JAVA技术进行XML编程(第一部分)-JSP教程,Java与XML
最新文章
·网关防护做得好web威胁少一半_教你一招教程
·计算机安全十大建议_教你一招教程
·给ie加个参数 永远不怕ie主页被修改_教你一招教程
·修改十四项设置 打造安全牢靠易用电脑_教你一招教程
·论垂直搜索引擎存在的意义_站长心得
·简单分析个人网站最缺少的几点要素_站长心得
·个人网站赢利探讨:网站究竟是如何盈利的?_站长心得
·网站设计的思考网页版面布局的原理_站长心得
·建立用自己域名结尾的hotmail邮箱2_站长心得
·随时保障系统安全五步搞定补丁管理部署_教你一招教程
相关主题
西部数码虚拟主机

友情链接
CNNIC 西部数码
万网 自助建站
虚拟主机 asp空间
域名注册 域名
域名申请 主页空间
论坛空间 网站空间
国际域名 虚拟空间
空间租用 DDOS防火墙
成都主机托管 四川主机托管
主机租用 服务器租用
网站目录 自助建站
虚拟主机 网址大全
软件下载
自助链接
虚拟主机资讯 特价虚拟主机
版权申明:本站文章均来自网络,如有侵权,请联系我们,我们收到后立即删除,谢谢!
关于我们:站长天空:专业提供最新的站长资讯、在线教程、虚拟主机权威评测、虚拟主机性能对比、网站制作教程,开发教程,站长工具。包括网页制作教程、冲浪宝典、编程参考、操作系统、软件教学、行业动态等。
特别注意:本站所有转载文章言论不代表本站观点,本站所提供的摄影照片,插画,设计作品,如需使用,请与原作者联系,版权归原作者所有。
发表评论 打印  刷新     关闭