UPDATE:此错误的修复已提交,并将在 Python 3.10 中首次亮相,预计将于 2021 年 10 月发布。请参阅错误报告 https://bugs.python.org/issue37205#msg381107了解详情。
的文档time.perf_counter() https://docs.python.org/3.7/library/time.html#time.perf_counter表明它是全系统
time.性能计数器() → float
返回性能计数器的值(以秒为单位),即
具有最高可用分辨率的时钟来测量较短的持续时间。
它确实包括睡眠期间经过的时间,并且是系统范围内的。这
返回值的参考点未定义,因此只有
连续调用结果之间的差异是有效的。
我的解释有误吗全系统包括跨流程的一致性?
如下所示,在Linux上看起来是一致的,但在Windows上却不一致。此外,Python 3.6 的 Windows 行为与 3.7 显着不同。
如果有人能指出涵盖此行为的文档或错误报告,我将不胜感激。
测试用例
import concurrent.futures
import time
def worker():
return time.perf_counter()
if __name__ == '__main__':
pool = concurrent.futures.ProcessPoolExecutor()
futures = []
for i in range(3):
print('Submitting worker {:d} at time.perf_counter() == {:.3f}'.format(i, time.perf_counter()))
futures.append(pool.submit(worker))
time.sleep(1)
for i, f in enumerate(futures):
print('Worker {:d} started at time.perf_counter() == {:.3f}'.format(i, f.result()))
Windows 7 上的结果
C:\...>Python36\python.exe -VV
Python 3.6.8 (tags/v3.6.8:3c6b436a57, Dec 24 2018, 00:16:47) [MSC v.1916 64 bit (AMD64)]
C:\...>Python36\python.exe perf_counter_across_processes.py
Submitting worker 0 at time.perf_counter() == 0.000
Submitting worker 1 at time.perf_counter() == 1.169
Submitting worker 2 at time.perf_counter() == 2.170
Worker 0 started at time.perf_counter() == 0.000
Worker 1 started at time.perf_counter() == 0.533
Worker 2 started at time.perf_counter() == 0.000
C:\...>Python37\python.exe -VV
Python 3.7.3 (v3.7.3:ef4ec6ed12, Mar 25 2019, 22:22:05) [MSC v.1916 64 bit (AMD64)]
C:\...>Python37\python.exe perf_counter_across_processes.py
Submitting worker 0 at time.perf_counter() == 0.376
Submitting worker 1 at time.perf_counter() == 1.527
Submitting worker 2 at time.perf_counter() == 2.529
Worker 0 started at time.perf_counter() == 0.380
Worker 1 started at time.perf_counter() == 0.956
Worker 2 started at time.perf_counter() == 1.963
为了简洁起见,我省略了 Windows 上的进一步结果,但在 Windows 8.1 上观察到了相同的行为。此外,Python 3.6.7 的行为与 3.6.8 相同,而 Python 3.7.1 的行为与 3.7.3 相同。
Ubuntu 18.04.1 LTS 上的结果
$ python3 -VV
Python 3.6.7 (default, Oct 22 2018, 11:32:17)
[GCC 8.2.0]
$ python3 perf_counter_across_processes.py
Submitting worker 0 at time.perf_counter() == 2075.896
Submitting worker 1 at time.perf_counter() == 2076.900
Submitting worker 2 at time.perf_counter() == 2077.903
Worker 0 started at time.perf_counter() == 2075.900
Worker 1 started at time.perf_counter() == 2076.902
Worker 2 started at time.perf_counter() == 2077.905
$ python3.7 -VV
Python 3.7.1 (default, Oct 22 2018, 11:21:55)
[GCC 8.2.0]
$ python3.7 perf_counter_across_processes.py
Submitting worker 0 at time.perf_counter() == 1692.514
Submitting worker 1 at time.perf_counter() == 1693.518
Submitting worker 2 at time.perf_counter() == 1694.520
Worker 0 started at time.perf_counter() == 1692.517
Worker 1 started at time.perf_counter() == 1693.519
Worker 2 started at time.perf_counter() == 1694.522