python3跑通smpl模型_Python中的负进程执行时间。如何正确测量?

本文探讨了在Python中使用多进程时遇到的问题,特别是在Windows环境下防止无限递归的方法。文章通过示例解释了`time.perf_counter()`在多进程中测量执行时间的不确定性,并建议使用`time.time()`来准确测量。最后,调整代码以更好地计算每个子进程的运行时间,揭示了对于短时间内运行的任务,创建子进程可能并不划算。
摘要由CSDN通过智能技术生成

首先,当您在Windows下运行时,请注意,您必须通过确保创建子进程的代码在由

if __name__ == '__main__':

,正如你所做的那样。原因是,当子进程被执行时,整个文件将被重新执行,您将进入一个创建新子进程的无限递归循环。但关键是你有代码

阻止你真的这么做

不需要也不想由每个子进程执行,即文件的打开和读取。应该移动此代码。

现在来看看你的神秘。根据手册

time.perf_counter()

:

注意上面最后一句话。有人打电话给这个

并行

来自多个进程。您认为对这个函数的调用在计算运行时间时为开始时间和结束时间赋值是连续的调用,但不能保证它们是连续调用。你真的需要用

time.time()

import multiprocessing as mp

import time

to_replace = 'az'

replace_with = '{[]}'

def process_txt(start_time, inp_text):

txt = list(inp_text)

for i, letter in enumerate(txt):

if letter in to_replace:

txt[i] = replace_with

txt = ''.join(txt)

print(txt + '\n')

print('Ran for ' + str(round(time.time() - start_time, 4)) + ' second(s)...\n

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值