计算2个时间之间经过多少Ticks
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的更多相关文章
- MySql计算两日期时间之间相差的天数,秒数,分钟数,周数,小时数
MySql计算两日期时间之间相差的天数,秒数,分钟数,周数,小时数 计算两日期时间之间相差的天数,秒数,分钟数,周数,小时数,这里主要分享的是通过MySql内置的函数 TimeStampDiff() ...
- oracle 计算两个时间之间的月份差,相差几个星期,相差多少天
相差多少天: sysdate-to_date('1991-01-01','YYYY-MM-DD'))<7 and (sysdate-to_date('1991=01=01','YYYY-MM ...
- js计算两个时间之间的间隔
计算时间间隔的方法有很多,这里只是一种方式,可以方法里直接传入两个时间,也可以传入两个字符串格式的时间,在方法里解析一下就ok,这个例子里不传入参数,直接在方法里随便写一个时间来演示一下 fun() ...
- sql计算两个时间之间的差,并用时分秒表示
这是自己写的方法,总觉得会有更好的办法实现这个效果呢? SELECT then ))))+'秒' then )))+'秒' then ))+'秒' else CONVERT(nvarchar,DATE ...
- mysql 计算两个时间之间有多少分钟
SELECT TIMESTAMPDIFF(MINUTE, (DATE_FORMAT('2015-08-12 10:38:00','%Y-%m-%d %H:%i')), (DATE_FORMAT('20 ...
- mysql计算两个日期之间的天数
MYSQL自带函数计算给定的两个日期的间隔天数 有两个途径可获得 1.利用TO_DAYS函数 select to_days(now()) - to_days('20120512') 2 ...
- PHP 计算两个时间戳之间相差的时间
//功能:计算两个时间戳之间相差的日时分秒 //$begin_time 开始时间戳 //$end_time 结束时间戳 function timediff($begin_time,$end_time) ...
- Python datetime库计算两个时间点之间的分钟(秒、天)数
计算两个时间点之间的分钟数 import datetime def minNums(startTime, endTime): '''计算两个时间点之间的分钟数''' # 处理格式,加上秒位 start ...
- java计算两个日期之间相隔的天数
import java.text.ParseException; import java.text.SimpleDateFormat; import java.util.Calendar; impor ...
随机推荐
- 关于z-index使用方法
z-index控制的是元素的层叠顺序,当z-index越大此层越靠上:但是z-index需在已给元素定位(定位方式不限)的前提下否则该属性失效!! jquery获取index值的方法: $(" ...
- ES6模块化与常用功能
目前开发环境已经普及使用,如vue,react等,但浏览器环境却支持不好,所以需要开发环境编译,下面介绍下开发环境的使用和常用语法: 一,ES6模块化 1,模块化的基本语法 ES6 的模块自动采用严格 ...
- PostgreSQL 10 如何使用 PgAdmin3
自从 PgAdmin4 出来以后,PgAdmin3 就停止开发了,PgAdmin 官网下载的 PgAdmin3 无法支持 PostgreSQL 10 或者更高版本的数据库服务器端. 但是 PgAdmi ...
- python自动化开发-6-常用模块-续
python的常用模块(续) shelve模块:是一个简单的k,v将内存数据通过文件持久化的模块,可以持久化任何pickle可支持的python数据格式. configparser模块:对配置文件进行 ...
- springboot 升级到2.0后 context-path 配置 不起作用,不生效 不管用 皆是因为版本改动导致的在这里记录一下
不知不觉,新的项目已经将springboot升级为2.0版本了.刚开始没有配置server.contextpath,默认的“/”,然后今天放到自己的服务器上,所以就要规范名称. 结果,失败了,无论我 ...
- 精通initramfs构建step by step
(一)hello world 一.initramfs是什么 在2.6版本的linux内核中,都包含一个压缩过的cpio格式 的打包文件.当内核启动时,会从这个打包文件中导出文件到内核的rootfs ...
- 洗礼灵魂,修炼python(11)--python函数,模块
前面的章节你如果看懂了,基本算是入门了七八了,不过如果你以为python就这么点东西,你觉得很简单啊,那你就错了,真正的东西在后面,前面我说的几大核心其实也不是多么高深多么厉害的,那些东西是基础很常用 ...
- sqlserver序列定时初始化
1.创建序列 2.序列初始化存储过程 create procedure proDemo as begin alter sequence dbo.序列名 restart with 0; end 3.创建 ...
- 利用PCA进行故障监测
利用PCA进行故障监测,传统的统计指标有两种:Hotelling-T2和平方预测误差(Squared prediction error, SPE).T2统计量反映了每个主成分在变化趋势和幅值上偏离模型 ...
- zookeeper-03 命令行操作
1. 前言 在3台机器分别部署了zookeeper-3.4.5,本文操作是在此基础上进行的.部署详情参见上一篇文章 2. 客户端登录与帮助查看 # 由于是集群模式,所以可以在3台机器的其中任意一台进行 ...