计算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 ...
随机推荐
- 《Inside C#》笔记(十五) 非托管代码 下
二编写不安全代码 a)fixed关键字 代码中体现了fixed的用法:fixed (type* ptr= expression) { …}:type是类似int*这样的非托管类型或void类型,exp ...
- (网页)Java程序员们最常犯的10个错误(转)
转自CSDN: 1.将数组转化为列表 将数组转化为一个列表时,程序员们经常这样做: List<String> list = Arrays.asList(arr); Arrays.asLis ...
- OneAPM大讲堂 | Metrics, Tracing 和 Logging 的关系
[编者按]这是在 OpenTracing 和分布式追踪领域内广受欢迎的一片博客文章.在构建监控系统时,大家往往在这几个名词和方式之间纠结. 通过这篇文章,作者很好的阐述了分布式追踪.统计指标与日志之间 ...
- [VMWARE] [CENTOS7] 安装VMware-Tools
安装VM-Tools 先使用yum install 安装Perl与net-tools# sudo yum install net-tools# sudo yum install perl 加载CDRO ...
- 如何使用C语言的面向对象
我们都知道,C++才是面向对象的语言,但是C语言是否能使用面向对象的功能? (1)继承性 typedef struct _parent { int data_parent; }Parent; type ...
- 第五章 绘图基础(SINEWAVE)
//SINEWAVE.C -- Sine Wave Using Polyline (c) Charles Petzold, 1998 #include <Windows.h> #inclu ...
- Linux远程访问及控制(SSH)
1.ssh协议:用于远程登录,端口号:22/tcp 配置文件: 1)服务器端口:/etc/ssh/sshd_config 2)客户端 :/etc/ssh/ssh_config 2.服务器监听选项: U ...
- navicat连接mysql时出现2003(10060)错误
问题解决步骤: 参考http://jingyan.baidu.com/article/95c9d20dac9040ec4f75617a.html,发现是防火墙未关闭: 那么我们就有两种方法去解决了 关 ...
- Activity声明周期1
oncreate():在Activity对象第一次创建时调用 onStart():当Activity变得可见时调用该函数 onResume():当Activity开始准备于用户交互时调用该方法(即获得 ...
- UOJ 【UR #5】怎样跑得更快
[UOJ#62]怎样跑得更快 题面 这个题让人有高斯消元的冲动,但肯定是不行的. 这个题算是莫比乌斯反演的一个非常巧妙的应用(不看题解不会做). 套路1: 因为\(b(i)\)能表达成一系列\(x(i ...