我有两个日期时间,一个来自时间戳,另一个是我在代码中生成的.我需要测试他们的平等,并且喜欢在没有太多表情的情况下做到这一点.这是我两个日期的一个例子:
DateTime expireTimeStampUTC =
DateTime.Parse(UTCValueFromDatabase));
DateTime expectedExpireTime =
DateTime.UtcNow.AddHours(NumberOfExpectedHoursInConfig);
Run Code Online (Sandbox Code Playgroud)
这是测试精度太高:
if(expireTimeStampUTC.Equals(expectedExpireTime)){}
我不在乎他们是否与第二小时完全相同.
它可能是做这样复合的最佳解决方案:
if (expireTimeStampUTC.Date.Equals(expectedExpireTime.Date))
{
if (!expireTimeStampUTC.Hour.Equals(expectedExpireTime.Hour))
{
pass = false;
}
}
Run Code Online (Sandbox Code Playgroud)
我不是最有经验的C#...是否有一些优雅的方法来做到这一点?
Col*_*itz 11
如果您遇到的问题是因为它们是数据库类型,您可以转换为该类型并进行比较,我们会在大约1/3的数据库保存中丢失/获得大约一毫秒的转换为SQLDateTimes.
如果没有,请比较您实际关注的单位:
DateTime dt1 = DateTime.UtcNow;
DateTime dt2 = DateTime.UtcNow.AddMinutes(59); // or 1 or 61 for test values;
// if the dates are in the same hour (12:10 == 12:50, 1:58 != 2:02)
if(dt1.Hour == dt2.Hour) // result
Run Code Online (Sandbox Code Playgroud)
或者如果你关心它们是在一小时的时间范围内
// if the dates are within one hour of each other (1:58 == 2:02, 3:30 != 4:45)
if((dt1 - dt2).Duration() < TimeSpan.FromHours(1)) // result
Run Code Online (Sandbox Code Playgroud)
这里减去日期会产生一个时间跨度,持续时间是'绝对值',然后我们从我们关心的单位(FromHours)明确地创建限制并进行比较.
最后一行是尽可能干净的,我认为在特定的时间跨度内做平等.
如何找到两个小时之间的差异,并查看它是否低于某个阈值(例如一小时3600秒)?
var diff = expireTimeStamp.Subtract(expectedExpireTime).TotalSeconds;
pass = Math.Abs(diff) < 3600;
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
3993 次 |
| 最近记录: |