Nesbot Carbon diffInHours 的奇怪结果

Weird results for Nesbot Carbon diffInHours

我正在 tinker 解决另一个关于 SO 的问题。 Carbon 的 diffInHours 有一些奇怪的行为。未来时间的差异与过去时间的差异不同。这是我的修补程序命令和 return 值:

>>> \Carbon\Carbon::now()->diffInHours(\Carbon\Carbon::now()->addHours(3))
=> 3
>>> \Carbon\Carbon::now()->addHours(3)->diffInHours(\Carbon\Carbon::now())
=> 2
>>> \Carbon\Carbon::now()->addHours(3)->diffInHours(\Carbon\Carbon::now())
=> 2
>>> \Carbon\Carbon::now()->addHours(3)->diffInHours(\Carbon\Carbon::now())
=> 2
>>> \Carbon\Carbon::now()
=> Carbon\Carbon @1595427497 {#4431
     date: 2020-07-22 14:18:17.952594 UTC (+00:00),
   }

有没有人知道是什么导致了这种行为?

\Carbon\Carbon::now()->addHours(3)->diffInHours(\Carbon\Carbon::now();

让我们分解一下以了解发生了什么:

1- 你得到代表现在的日期时间。

2- 你加了 3 个小时。结果将是现在 + 3 小时。

3- 你得到 diffInHours 'now'( 与第一个 'now' 相差几分之一秒) 将是 2.9999999180556

4- diffInHours 将结果向下舍入 (as in doc),结果将是 2 ..

如果你想在不舍入的情况下获得真正的差异,你可以使用 floatDiffInRealHours,这会给你 2.9999999180556

问题是调用两个 \Carbon\Carbon::now() 之间的延迟。如果您使用复制的 Carbon 实例,您可以看到没有问题:

>>> $now = \Carbon\Carbon::now()
=> Carbon\Carbon @1595429110 {#4367
     date: 2020-07-22 14:45:10.767156 UTC (+00:00),
   }
>>> $threeHoursFromNow = $now->copy()->addHours(3)
=> Carbon\Carbon @1595439910 {#4428
     date: 2020-07-22 17:45:10.767156 UTC (+00:00),
   }
>>> $now->diffInHours($threeHoursFromNow)
=> 3
>>> $threeHoursFromNow->diffInHours($now)
=> 3