3

我正在tinker为 SO 上的另一个问题做一些研究。并且对 Carbon 的 diffInHours 有一些奇怪的行为。前面时间的差异与过去的时间差异不同。这是我的修补程序命令和返回值:

>>> \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),
   }

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

4

1 回答 1

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

让我们分解它以弄清楚发生了什么:

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

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

3-你得到 diffInHours 与'now'(女巫与第一个'now'之后的几分之一秒不同)女巫将是 2.9999999180556

4- diffInHours 将结果向下舍入(如 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
于 2020-07-22T14:46:57.917 回答