Ticks是一个周期,存储的是一百纳秒,换算为秒,一千万分之一秒。
我们需要计算2个时间之间,经过多少Ticks,可以使用下面的方法来实现,使用2个时间相减。

得到结果为正数,是使用较晚的时间减去较早的时间。反之为负数,即是使用较早的时间减去较晚的时间。

创建一个对象:

 class Ag
{
private DateTime _StartDate; public DateTime StartDate
{
get { return _StartDate; }
set { _StartDate = value; }
}
private DateTime _EndDate; public DateTime EndDate
{
get { return _EndDate; }
set { _EndDate = value; }
} public Ag(DateTime startDate, DateTime endDate)
{
this._StartDate = startDate;
this._EndDate = endDate;
} public void DurationTicks()
{
TimeSpan ts = (_EndDate - _StartDate).Duration();
Console.WriteLine(ts.Ticks);
}
}

Source Code

在控制台应用程序运行上面写好的程序:

现在来了,实际情况并非都是计算2个时间之间的Ticks,而是有可能需要计算2个时间之间的秒,分钟,小时,天等。
为了实现上面的要求,我们得了解一些基础知识:
1天= 24;
1小时= 60分钟;
1分钟= 60秒;
1秒= 10000000Ticks;

因此,根据上面的计算结果(Ticks)和公式可以计算出2个时间之间的秒,分钟,小时,天等。

我们在类别中,添加下面4个方法:

 public void DurationSeconds()
{
TimeSpan ts = (_EndDate - _StartDate).Duration();
Console.WriteLine("Duraction Seconds: {0}", ts.Ticks / 10000000L);
} public void DurationMinutes()
{
TimeSpan ts = (_EndDate - _StartDate).Duration();
Console.WriteLine("Duraction Minutes: {0}",ts.Ticks / (10000000L * ));
} public void DurationHours()
{
TimeSpan ts = (_EndDate - _StartDate).Duration();
Console.WriteLine("Duraction Hours: {0}", ts.Ticks / (10000000L * * ));
} public void DurationDays()
{
TimeSpan ts = (_EndDate - _StartDate).Duration();
Console.WriteLine("Duraction Days: {0}", ts.Ticks / (10000000L * * * ));
}

Source Code

方法写完,在控制台测试一下上面的方法:

上面的计算方法有点原始,MSDN已经给出相应的方法,就可以计算出2个时间之间的秒,分钟,小时,天等。如:
TotalSeconds(),TotalMinutes(),TotalHours(),TotalDays();
为了演示与测试,Insus.NET再创建另外4个方法:

  public void TotalSeconds()
{
TimeSpan ts = (_EndDate - _StartDate).Duration();
Console.WriteLine("Duraction Seconds: {0}", ts.TotalSeconds);
} public void TotalMinutes()
{
TimeSpan ts = (_EndDate - _StartDate).Duration();
Console.WriteLine("Duraction Minutes: {0}", ts.TotalMinutes);
} public void TotalHours()
{
TimeSpan ts = (_EndDate - _StartDate).Duration();
Console.WriteLine("Duraction Hours: {0}", ts.TotalHours);
} public void TotalDays()
{
TimeSpan ts = (_EndDate - _StartDate).Duration();
Console.WriteLine("Duraction Days: {0}", ts.TotalDays);
}

Source Code

再运行程序:

最后的现成的方法,它已经封装好单位转换与公式计算。

细心的用户有可以发现,2种结果有些不相同,没有小数和有小数。其实可以解决的,把一千万分之一秒这个基数转换为double数据类型即可。也就是说把能来的L-->D:

 public void DurationSeconds()
{
TimeSpan ts = (_EndDate - _StartDate).Duration();
// Console.WriteLine("Duraction Seconds: {0}", ts.Ticks / 10000000L);
Console.WriteLine("Duraction Seconds: {0}", ts.Ticks / 10000000D);
} public void DurationMinutes()
{
TimeSpan ts = (_EndDate - _StartDate).Duration();
// Console.WriteLine("Duraction Minutes: {0}", ts.Ticks / (10000000L * 60));
Console.WriteLine("Duraction Minutes: {0}", ts.Ticks / (10000000D * ));
} public void DurationHours()
{
TimeSpan ts = (_EndDate - _StartDate).Duration();
// Console.WriteLine("Duraction Hours: {0}", ts.Ticks / (10000000L * 60 * 60));
Console.WriteLine("Duraction Hours: {0}", ts.Ticks / (10000000D * * ));
} public void DurationDays()
{
TimeSpan ts = (_EndDate - _StartDate).Duration();
// Console.WriteLine("Duraction Days: {0}", ts.Ticks / (10000000L * 60 * 60 * 24));
Console.WriteLine("Duraction Days: {0}", ts.Ticks / (10000000D * * * ));
}

Source Code

这次,我们再次运行程序,看看结果是否与自带的方法计算的结果相同:

OK,就这样子,你可以使用自带现成的方法,可以自己写。

写到这里应该是结果了,但是回过头来看看自己写的代码,有一句:

TimeSpan ts = (_EndDate - _StartDate).Duration();

每一个方法里均有,代码冗余了,我们可以简化它,写一个方法或是属性:

public TimeSpan Ts
{
get
{
return (_EndDate - _StartDate).Duration();
}
} public long Ticks
{
get
{
return Ts.Ticks;
}
}

Source Code

经过一次重构,8个方法里,只需要一句代码就行了:

计算2个时间之间经过多少Ticks的更多相关文章

  1. MySql计算两日期时间之间相差的天数,秒数,分钟数,周数,小时数

    MySql计算两日期时间之间相差的天数,秒数,分钟数,周数,小时数 计算两日期时间之间相差的天数,秒数,分钟数,周数,小时数,这里主要分享的是通过MySql内置的函数 TimeStampDiff() ...

  2. oracle 计算两个时间之间的月份差,相差几个星期,相差多少天

    相差多少天:   sysdate-to_date('1991-01-01','YYYY-MM-DD'))<7 and (sysdate-to_date('1991=01=01','YYYY-MM ...

  3. js计算两个时间之间的间隔

    计算时间间隔的方法有很多,这里只是一种方式,可以方法里直接传入两个时间,也可以传入两个字符串格式的时间,在方法里解析一下就ok,这个例子里不传入参数,直接在方法里随便写一个时间来演示一下 fun() ...

  4. sql计算两个时间之间的差,并用时分秒表示

    这是自己写的方法,总觉得会有更好的办法实现这个效果呢? SELECT then ))))+'秒' then )))+'秒' then ))+'秒' else CONVERT(nvarchar,DATE ...

  5. mysql 计算两个时间之间有多少分钟

    SELECT TIMESTAMPDIFF(MINUTE, (DATE_FORMAT('2015-08-12 10:38:00','%Y-%m-%d %H:%i')), (DATE_FORMAT('20 ...

  6. mysql计算两个日期之间的天数

    MYSQL自带函数计算给定的两个日期的间隔天数   有两个途径可获得   1.利用TO_DAYS函数   select to_days(now()) - to_days('20120512')   2 ...

  7. PHP 计算两个时间戳之间相差的时间

    //功能:计算两个时间戳之间相差的日时分秒 //$begin_time 开始时间戳 //$end_time 结束时间戳 function timediff($begin_time,$end_time) ...

  8. Python datetime库计算两个时间点之间的分钟(秒、天)数

    计算两个时间点之间的分钟数 import datetime def minNums(startTime, endTime): '''计算两个时间点之间的分钟数''' # 处理格式,加上秒位 start ...

  9. java计算两个日期之间相隔的天数

    import java.text.ParseException; import java.text.SimpleDateFormat; import java.util.Calendar; impor ...

随机推荐

  1. VUE CLI 3.0 项目引入 ElementUI

    ElementUI 官网: http://element-cn.eleme.io/#/zh-CN/component/installation 一.通过npm安装依赖包 1. 进入到项目目录,执行指令 ...

  2. Jmeter进阶篇之监控服务器cpu,内存

    对于Jmeter,可以不再赘述,因为介绍得也够多了. 那么相信有部分同学已经尝试着自主去学习如果使用Jmeter对服务器进行压力测试了. 但是可能也会发现,Jmeter好像监控不了服务器的cpu已经内 ...

  3. 我的Java之旅 第七课 JAVA WEB 会话管理

    1.隐藏域       隐藏域其实不是Servlet/JSP的会话管理机制的内容,但它能实现简单的页面状态记录的效果. 2.Cookie    Cookie类    setMaxAge() 设置有效期 ...

  4. Tomcat 8默认工具manager管理页面访问配置

    Tomcat 8默认工具manager管理页面访问配置 1. 分配相关的角色权限 需要配置的配置文件是${catalina.home}/conf/tomcat-users.xml先给Tomcat访问相 ...

  5. 《Inside C#》笔记(十二) 委托与事件

    C#的委托与C++的函数指针类似,但委托是类型安全的,意味着指针始终会指向有效的函数.委托的使用主要有两种:回调和事件. 一 将委托作为回调函数 在需要给一个函数传递一个函数指针,随后通过函数指针调用 ...

  6. linux上部署engineercms、docker和onlyoffice实现文档协作

    等了好久,这次终于下决心在局域网部署了linux系统,并安装docker和load了onlyoffice,利用engineercms进行资料管理和文档协作. 我整理了完整文档,见我的网盘. engin ...

  7. 小技巧-mac修改finder菜单栏

    效果: 方法: 添加:打开finder后,长按command,可以将其他app拖到菜单栏. 删除:同理,长按command,将不需要的图标拖出菜单栏即可. PS:强烈推荐gotoshell这个小工具, ...

  8. tkinter中Radiobutton单选框控件(七)

    Radiobutton控件 由于本次内容中好多知识都是之前重复解释过的,本次就不做解释了.不太清楚的内容请参考tkinter1-6节中的内容 import tkinter wuya = tkinter ...

  9. 大表分批删除脚本之MySQL版

    经常需要定期对某些表删除历史数据,通常这样的表的数据又是非常巨大,为了减轻对线上环境的影响,删除时必须分成小批量来进行. 以前分享过SQLServer的版本. 下面是MySQL版本: delimite ...

  10. 在VS 一切正常,发布到IIS出现问题 [System.Data.OracleClient 需要 Oracle 客户端软件 version 8.1.7 或更高版本]

    在VS 一切正常,发布到IIS出现问题 [System.Data.OracleClient 需要 Oracle 客户端软件 version 8.1.7 或更高版本] 前提条件: 在vs 开发的时候,一 ...