python中进程池multiprocessing.Pool运行错误:若程序不使用生成exe文件,则可以省略freeze_support()函数
在python中,多进程是一种很好的提高程序性能的方式,而进程池又是多进程编程中常用的一种方式。然而在使用multiprocessing.Pool时,可能会遇到“RuntimeError: An attempt has been made to start a new process before the current process has finished its bootstrapping phase”的错误。
这个错误是由于在Windows平台下,主程序和子进程都会执行一遍代码,而之前已经执行过的部分代码重复执行就会发生错误。为了解决这个问题,Python官方文档建议在脚本中添加如下代码:
if __name__ == '__main__':
freeze_support()
其中freeze_support()是一个冻结(Windows平台下的exe文件生成)进程的功能函数,但是在使用multiprocessing.Pool时,我们并不需要将程序生成exe文件,因此可以将该行代码省略。
以下是一个简单的使用multiprocessing.Pool的示例代码ÿ