Python manager.dict() is very slow compared to regular dict

前端 未结 2 2176
悲&欢浪女
悲&欢浪女 2021-02-14 09:36

I have a dict to store objects:

jobs = {}
job = Job()
jobs[job.name] = job

now I want to convert it to use manager dict because I want to use m

相关标签:
2条回答
  • 2021-02-14 09:53

    The problem is that each insert is quite slow for some reason (117x slower on my machine), but if you update your manager.dict() with a normal dict, it will be a single and fast operation.

    jobs = {}
    job = Job()
    jobs[job.name] = job
    # insert other jobs in the normal dictionary
    
    mgr = multiprocessing.Manager()
    mgr_jobs = mgr.dict()
    mgr_jobs.update(jobs)
    

    Then use the mgr_jobs variable.

    Another option is to use the widely adopted multiprocessing.Queue class.

    0 讨论(0)
  • 2021-02-14 10:11

    If you are using mgr.dict() inside a loop in your pool. You can use a local normal dict to store results temporarily and then update your mgr.dict() outside the loop like your_mgr_dict.update(local_dict)

    0 讨论(0)
提交回复
热议问题