首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >在Python的多处理包中,为什么存在multiprocessing.Pool和multiprocessing.pool.Pool?

在Python的多处理包中,为什么存在multiprocessing.Pool和multiprocessing.pool.Pool?
EN

Stack Overflow用户
提问于 2015-07-28 00:40:54
回答 1查看 449关注 0票数 3

在学习Python的multiprocessing包(用于Python 3.4)时,我注意到multiprocessing.Pool是在context.py中的类BaseContext中定义的。这个定义是

代码语言:javascript
复制
   def Pool(self, processes=None, initializer=None, initargs=(),
         maxtasksperchild=None):
    '''Returns a process pool object'''
    from .pool import Pool
    return Pool(processes, initializer, initargs, maxtasksperchild,
                context=self.get_context())

因此,它最终调用了在multiprocessing.pool.Pool中定义的pool.py

为什么multiprocessing包同时定义了multiprocessing.Poolmultiprocessing.pool.Pool

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2015-07-28 01:04:48

context.py包含与操作系统相关的代码.Pool和许多其他值的定义是不同的,这取决于是否sys.platform == 'win32'

pool.py模块包含与创建给定上下文的池相关的代码。

通过以这种方式组织代码,开发人员设法以一种与操作系统无关的方式编写pool.py。例如,在if sys.platform ...中没有pool.py语句。

__init__.py包含:

代码语言:javascript
复制
globals().update((name, getattr(context._default_context, name))
                 for name in context._default_context.__all__)
__all__ = context._default_context.__all__

将值从context._default_context复制到multiprocessing包的命名空间中。multiprocessing.Pool就是这样定义的。

作为multiprocessing包的用户,您需要通过multiprocessing.Pool访问池,尽管也可以使用multiprocessing.pool.Pool

票数 3
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/31665641

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档