getTime public long getTime() 返回自 1970 年 1 月 1 日 00:00:00 GMT 以来此 Date 对象表示的毫秒数。 返回: 自 1970 年 1 月 1 日 00:00:00 GMT 以来此日期表示的毫秒数。 .net DateTime.Ticks public long Ticks {get;}      属性值

表示此实例的日期和时间的刻度数。该值介于 MinValue 和 MaxValue 之间。

备注

此属性的值为自 0001 年 1 月 1 日午夜 12:00 以来所经过时间以 100 毫微秒为间隔表示时的数字。

1秒=1000毫秒(ms) 1毫秒=1/1,000秒(s) 1秒=1,000,000 微秒(μs) 1微秒=1/1,000,000秒(s) 1秒=1,000,000,000 纳秒(ns) 1纳秒=1/1,000,000,000秒(s) 1秒=1,000,000,000,000 皮秒(ps)

1 毫秒 = 10^-3 秒, ------->10的-3次方 小数点从1开始向左移3位即0.001 1 微秒 = 10^-6 秒, 1 毫微秒 = 10^-9 秒, 100 毫微秒 = 10^-7 秒。

Console.WriteLine(DateTime.Now.Ticks); // 输出:633603924670937500

也就是说,从0001 年 1 月 1 日午夜 12:00:00 以来到现在已经过了  633603924670937500 * 10^-7 秒。

很少用,除非需要很精确地知道从那时(1年1月1日)开始过了多少时间。

比如精确地计算两个时间差时(想知道某段程序运行了多少毫微秒)就可以用到。

1.using System;  2.using System.Collections.Generic;  3.  4.class Sentence  5.{  6.  static void Main()  7.  {  8.    long ticks0 = DateTime.Now.Ticks;  9.    for (int i = 0; i < int.MaxValue; i++)  10.    {  11.      // ...  12.    }  13.    long ticks1 = DateTime.Now.Ticks;  14.    long n = (ticks1 - ticks0) * 100;  15.    Console.WriteLine("上面这段程序运行了{0}毫微秒", n);  16.  }  17.}

转换成秒比用毫微秒更直观些:

1.using System;  2.using System.Collections.Generic;  3.  4.class Sentence  5.{  6.  static void Main()  7.  {  8.    long ticks0 = DateTime.Now.Ticks;  9.    for (int i = 0; i < int.MaxValue; i++)  10.    {  11.      // ...  12.    }  13.    long ticks1 = DateTime.Now.Ticks;  14.    double n = (ticks1 - ticks0) / 10000000.0;  15.    Console.WriteLine("上面这段程序运行了{0}秒", n);  16.  }  17.}

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

DateTime.Now的精度是很低,这个低的意思是,两次获取的DateTime.Now的Ticks的差,只是一个较大数的整数倍。例如在我 的机器上,这个差最小是10.114ms。所以,如果我用DateTime.Now来计算时间差,那么就无法精确到10ms以内。

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

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

我自己了按照这个写了个类,代码如下:

1.using System;  2.using System.Runtime.InteropServices;  3.public class A  4.{  5.    [DllImport("kernel32.dll")]  6.    static extern bool QueryPerformanceCounter([In, Out] ref long lpPerformanceCount);  7.    [DllImport("kernel32.dll")]  8.    static extern bool QueryPerformanceFrequency([In, Out] ref long lpFrequency);  9.  10.    static long _f = 0;  11.  12.    static public long GetTickCount()  13.    {  14.        long f = _f;  15.  16.        if (f == 0)  17.        {  18.            if (QueryPerformanceFrequency(ref f))  19.            {  20.                _f = f;  21.            }  22.            else  23.            {  24.                _f = -1;  25.            }  26.        }  27.        if (f == -1)  28.        {  29.            return Environment.TickCount * 10000;  30.        }  31.        long c = 0;  32.        QueryPerformanceCounter(ref c);  33.        return (long)(((double)c) * 1000 * 10000 / ((double)f));  34.    }  35.  36.    //GetTickCount()为0时的DateTime.Ticks值  37.    static long _tc = 0;  38.  39.    //这个返回的不是真正的精确时间,但时间与时间的差是精确的。  40.    //GetExactNow与DateTime.Now的偏差比DateTime.Now的精度还要小,所以该偏差  41.    static public DateTime GetExactNow()  42.    {  43.        if (_tc == 0)  44.        {  45.            long tc = GetTickCount();  46.            DateTime dt = DateTime.Now;  47.            _tc = dt.Ticks - tc;  48.            return dt;  49.        }  50.  51.        return new DateTime(_tc + GetTickCount());  52.    }  53.}

在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)

1秒=1000000000毫微秒   10亿

1秒=1000000000毫微秒

1秒=1000000000毫微秒(10亿分之一秒)

1秒=1000豪秒 1毫秒=1000微秒 1微秒=1000毫微秒 所以1秒=1000*1000*1000=1000000000毫微秒

1秒=1000豪秒 1毫秒=1000微秒 1微秒=1000毫微秒 1毫微秒=1纳秒 1纳秒=10埃秒

1秒   =   1000   毫秒         =   1000000   微秒         =   1000000000   毫微秒         =   1000000000   纳秒         =   1000000000000   皮秒

1s   =   1000   ms       =   1000000   us       =   1000000000   ns       =   1000000000000   ps

1(秒)=10的9次方(毫微秒)

<!--End_rbody_41637559//--><!--End_rbody_41637167//-->

DataTime.Now.Ticks的更多相关文章

  1. DataTime.Now.Ticks的应用

    参考:http://www.cnblogs.com/delphinet/archive/2011/06/09/2075985.html 转换成秒: using System; using System ...

  2. 关于DateTime.Now.Ticks

    DataTime.Now.Ticks 的值表示自 0001 年 1 月 1 日午夜 12:00:00 以来所经历的以 100 纳秒为间隔的间隔数,可用于较精确的计时. 1秒=1000豪秒 1毫秒=10 ...

  3. [No00003B]string格式的日期时间字符串转为DateTime类型

    新建console程序,复制粘贴直接运行: /**/ //using System.Globalization;//代码测试大致时间2015/11/3 15:09:05 //方法一:Convert.T ...

  4. Unity的常用API

    1.Event Function:事件函数   Reset() :被附加脚本时.在游戏物体的组件上按Reset时会触发该事件函数 Start() :在游戏初始化时会执行一次 Update() :每一帧 ...

  5. 【watcher】 #02 c# 中实现时间戳等,日期数字及大概率绝对随机数 实现

    在Wacher的项目中,用到了很多时间记录的地方,为了将来能够和在线数据打通,我们使用了时间戳来记录时间信息 由于c# 没有现成的方法,所以我们重新写了一个Helper类来帮助我们使用这些公共函数 同 ...

  6. c#滑窗缓存

    前言 在大数据时代,软件系统需要具备处理海量数据的能力,同时也更加依赖于系统强大的存储能力与数据响应能力.各种大数据的工具如雨后春笋般孕育而生,这对于系统来说是极大的利好.但在后端采用分布式.云存储和 ...

  7. Unity3D_(API)Random随机数

    Unity随机数Random官方文档: 传送门 一.生成一个随机数 二.Random.InitState()生成伪随机数 三.官方文档中常用的方法 创建一个Cube用来挂载Random_Gary.cs ...

  8. C# 中Datatime类用法总结

    C# 中Datatime类用法总结 收集了一些记录下来,这些有的是从网上找的,有些是自己使用到的: DateTime dt = DateTime.Now; dt.ToString();//2005-1 ...

  9. C# 中的时间(DataTime)

    在做报表或查询的时候,常常会预设一些可选的日期范围,如本周.本月.本年等,利用 C# 内置的DateTime基本上都可以实现这些功能. 当前时间: DateTime dt = DateTime.Now ...

随机推荐

  1. 冲刺阶段——Day4

    [今日内容] 完成对登陆成功后输入数据界面的设计,以及对Jswing组件功能的正确使用 布局类代码(布局部分是该类其中的一个部分,下述代码没有构成完整的类) public class NewGold ...

  2. python获取当前py文件的文件名或者当前工具箱的名字

    #########################import arcpy import osimport sys ########################################## ...

  3. java中json的使用和解析

    1.创建json对象 1.1 创建JSONObject对象 使用map初始化json @Test public void test1() { Map<String, Object> map ...

  4. SpringBoot/SpringMVC 下载本地文件

    页面代码: <!DOCTYPE html> <html lang="utf-8"> <meta http-equiv="Content-Ty ...

  5. Canvas-基本用法

    Canvas教程-MDN HTML 5 Canvas 参考手册 <canvas>是一个可以使用脚本(通常为JavaScript)来绘制图形的 HTML 元素.例如,它可以用于绘制图表.制作 ...

  6. SQL-W3School-高级:SQL NULL 值

    ylbtech-SQL-W3School-高级:SQL NULL 值 1.返回顶部 1. NULL 值是遗漏的未知数据. 默认地,表的列可以存放 NULL 值. 本章讲解 IS NULL 和 IS N ...

  7. 运行React Native项目出现白屏,无法运行

    运行React Native出现白屏,无法运行,查看终端报错如下: 原因: 代码中有语法错误,导致运行失败. 其实到这里可以去Xcode查看控制台打印,会提示哪个文件出现错误的. 解决办法: 找到报错 ...

  8. 建立第一个Django工程---linux中的python

    建立第一个Django工程 环境: ip: 192.168.0.92 系统:centos7.5 安装django pip install django 启动一个HelloWorld工程 django- ...

  9. Elasticsearch删除数据操作,你必须知道的一些坑

    前两天有同事打电话问我,说ES删除数据有没有什么坑? 我当时就问,是删索引还是删索引里的数据?她回答说是删数据,我说查出这些数据直接删除就好了,没有什么坑... 后来想想,关于ES数据的删除,之前确实 ...

  10. celery监控工具flower

    特性 用Celery事件实时监控 任务进程和历史 能够显示任务的详细信息(arguments, start time, runtime等) 图形化和统计 远程控制 查看worker状态和统计 关闭和重 ...