Использование многопроцессорности в MacOS против Windows - PullRequest
0 голосов
/ 03 мая 2018

Я использую multiprocessing.pool и по умолчанию использую macOS, но мне также нужно попробовать это в Windows. Он отлично работает на macOS, однако, когда я пытаюсь запустить на Windows, он просто отображает неограниченное количество сообщений об ошибках ... и я даже не могу убить программу.

Я видел, что метод запуска в Windows - "spawn", а в macOS - "fork" по умолчанию. Это проблема? Если да, как я могу это решить?

Часть кода ниже:

        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()

РЕДАКТИРОВАТЬ1:

Мне удалось получить сообщение об ошибке, мой плохой.

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.
...