鱼C论坛

 找回密码
 立即注册
查看: 1548|回复: 3

[已解决]测量代码运行时间的问题

[复制链接]
发表于 2018-1-31 16:35:59 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
请问time.perf_counter() 和time.process_time() 有什么区别啊?   看作业后面的示意是一个记录电脑睡眠时间    一个不记录          请问有具体一点的解释吗?
最佳答案
2018-1-31 22:51:39
相同点:
1. 都可以用于记录运行的精确时间
2.连续时间的差值才有效

不同点:
1.time.perf_counter() : 包含了睡眠时间(即整体的时间)
2.time.process_time() : 只针对CPU的执行时间

具体用哪个还需要根据自己的需求来判定,比如你只考虑CPU的速度那么你用 time.process_time()会更精确一点,因为他它忽略了类似于 time.sleep 这样的睡眠干扰。

举个栗子:
  1. import time
  2. t1 = time.perf_counter()
  3. t3 = time.process_time()
  4. for i in range(10):
  5.     print(i)
  6.     time.sleep(1)
  7. t2 = time.perf_counter()
  8. t4 = time.process_time()
  9. print('time.perf_counter : ',t2-t1)
  10. print('time.process_counter : ',t4-t3)
  11. #=======运行结果========
  12. 0
  13. 1
  14. 2
  15. 3
  16. 4
  17. 5
  18. 6
  19. 7
  20. 8
  21. 9
  22. time.perf_counter :  10.192253560388073
  23. time.process_counter :  0.0
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2018-1-31 22:51:39 | 显示全部楼层    本楼为最佳答案   
相同点:
1. 都可以用于记录运行的精确时间
2.连续时间的差值才有效

不同点:
1.time.perf_counter() : 包含了睡眠时间(即整体的时间)
2.time.process_time() : 只针对CPU的执行时间

具体用哪个还需要根据自己的需求来判定,比如你只考虑CPU的速度那么你用 time.process_time()会更精确一点,因为他它忽略了类似于 time.sleep 这样的睡眠干扰。

举个栗子:
  1. import time
  2. t1 = time.perf_counter()
  3. t3 = time.process_time()
  4. for i in range(10):
  5.     print(i)
  6.     time.sleep(1)
  7. t2 = time.perf_counter()
  8. t4 = time.process_time()
  9. print('time.perf_counter : ',t2-t1)
  10. print('time.process_counter : ',t4-t3)
  11. #=======运行结果========
  12. 0
  13. 1
  14. 2
  15. 3
  16. 4
  17. 5
  18. 6
  19. 7
  20. 8
  21. 9
  22. time.perf_counter :  10.192253560388073
  23. time.process_counter :  0.0
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2018-2-1 11:19:43 | 显示全部楼层
original.F 发表于 2018-1-31 22:51
相同点:
1. 都可以用于记录运行的精确时间
2.连续时间的差值才有效

我之前也是这个结果,使用time.process_time()结果是 0.0   我当时还以为是出错了呢     是因为函数内容太短    所以计算时间短到小数点后一位都无法记录吗?
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2018-2-2 22:27:23 | 显示全部楼层
特懒人员. 发表于 2018-2-1 11:19
我之前也是这个结果,使用time.process_time()结果是 0.0   我当时还以为是出错了呢     是因 ...

时间太短近似于0啊,你要看效果的话,建议循环100以上
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2026-3-6 16:22

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表