我了解 time.perf_counter() 测量经过的总时间,即使进程当前未运行。然而 time.process_time() 仅测量进程实际运行的时间。
如果我只是衡量一个功能的性能,这两个中哪一个是首选?
由于我实际上对 CPU 花在处理其他进程上的时间并不感兴趣,所以我自然认为 time.process_time() 会是更好的选择(并且在不同的运行中更稳定?),但名称 time.perf_counter() 似乎否则建议。
代码示例
import time
from tqdm import trange
start_time_proc = time.process_time()
start_time_perf = time.perf_counter()
tmp = False
for _ in trange(10_000_000):
tmp = not tmp
elapsed_time_proc = time.process_time() - start_time_proc
elapsed_time_perf = time.perf_counter() - start_time_perf
print("process_time:", elapsed_time_proc)
print("perf_counter:", elapsed_time_perf)
https://repl.it/repls/GigaSpryScientists#main.py
浮云间
相关分类