比较C#中两个DateTime的相等性的最佳方法是什么?但只有一定的精度?

dan*_*sky 6 c# datetime date

我有两个日期时间,一个来自时间戳,另一个是我在代码中生成的.我需要测试他们的平等,并且喜欢在没有太多表情的情况下做到这一点.这是我两个日期的一个例子:

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)明确地创建限制并进行比较.

最后一行是尽可能干净的,我认为在特定的时间跨度内做平等.


Mat*_*ton 6

如何找到两个小时之间的差异,并查看它是否低于某个阈值(例如一小时3600秒)?

var diff = expireTimeStamp.Subtract(expectedExpireTime).TotalSeconds;
pass = Math.Abs(diff) < 3600;
Run Code Online (Sandbox Code Playgroud)