【问题标题】:Why does DateTime.UtcNow.Subtract give me a massive number sometimes?为什么 DateTime.UtcNow.Subtract 有时会给我一个很大的数字?
【发布时间】:2019-09-28 11:58:13
【问题描述】:

为什么 DateTime.Subtract 有时会返回非常奇怪的值?

private ConcurrentDictionary<string, Request> _waitingList = new ConcurrentDictionary<string, Request>();

// send requests in thread #1 and set their SentAt time
_waitingList.TryAdd(macAddress, request);
request.SentAt = DateTime.UtcNow;

// then in a timer tick event in different thread every 5 seconds
private void OnTimerTick(object sender, ElapsedEventArgs e) {
   foreach (var waiting in _waitingList) { // ConcurrentDictionary<string, Request>
      var request = waiting.Value;
      var msSinceSent = DateTime.UtcNow.Subtract(request.SentAt).TotalMilliseconds;
        Debug.WriteLine($"sent *{request.Type}* {msSinceSent} ms ago");
   }
}
sent *PackageUpdate* 336.2019 ms ago
sent *PackageUpdate* 698.1145 ms ago
sent *PackageUpdate* 1059.864 ms ago
sent *PackageUpdate* 63693095680615.5 ms ago

最后一个值是巨大的,我经常得到这些,甚至无法理解这是怎么可能的。

【问题讨论】:

  • request.SentAt是什么数据类型?
  • @DavidG 日期时间
  • 你确定你使用的是.Milliseconds而不是.TotalMilliseconds吗?
  • @DavidG 是的,对不起,我正在使用 .TotalMilliseconds,我在最后一分钟刚刚更改了它。我已经用所有细节更新了我的问题,但没有太多。

标签: c# multithreading datetime timer


【解决方案1】:

如果request.SentAt 设置为DateTime.MinValue,您将获得该值。我假设它在您的数据存储中为 null 或零,并且正在某个地方转换为 DateTime.MinValue

例如这段代码:

Console.WriteLine(DateTime.UtcNow.Subtract(DateTime.MinValue).TotalMilliseconds);

会输出这个值:

63693097183442.7

【讨论】:

    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 2023-03-28
    • 2013-06-18
    • 1970-01-01
    • 1970-01-01
    • 2015-12-29
    • 2011-08-12
    • 2013-11-14
    相关资源
    最近更新 更多