python - Brug multiprocessing på macOS vs. Windows

Indlæg af Hanne Mølgaard Plasc

Problem



Jeg bruger ms multiprocessing.pool, og jeg bruger macOS som standard, men jeg skal også prøve det på Windows. Det kører perfekt på macOS, men når jeg prøver at køre på Windows, vises det bare ubegrænsede fejlmeddelelser ... og jeg kan t selv dræbe programmet.


Jeg har set, at startmetoden på Windows er 'spawn' og på MacOS er 'Gaffel' som standard. Er dette problemet? Hvis ja, hvordan kan jeg løse det?


En del af koden nedenfor:


        pool = Pool(processes = numprocs)
        # evaluate fitness of particles in swarm
        swarm = pool.map\_async(partial(proxy, costf = costFunc, i=i),Swarm)
        pool.close()
        pool.join()
        pool.terminate()

        Swarm = swarm.get()


Edit1:


Jeg kunne få fejlmeddelelsen, min dårlige.


RuntimeError:
        An attempt has been made to start a new process before the
        current process has finished its bootstrapping phase.

        This probably means that you are not using fork to start your
        child processes and you have forgotten to use the proper idiom
        in the main module:

            if \_\_name\_\_ == '\_\_main\_\_':
                freeze\_support()
                ...

        The "freeze\_support()" line can be omitted if the program
        is not going to be frozen to produce an executable.

Bedste reference