python queue get 方法_Python queue.SimpleQueue方法代码示例

本文介绍了Python中的queue.SimpleQueue模块,包括如何导入和初始化SimpleQueue,以及在多进程池(Pool)中使用SimpleQueue进行任务调度。通过示例展示了其在创建线程和管理进程间通信中的应用。
摘要由CSDN通过智能技术生成

# 需要导入模块: import queue [as 别名]

# 或者: from queue import SimpleQueue [as 别名]

def __init__(self, processes=None, initializer=None, initargs=(),

maxtasksperchild=None, context=None):

self._ctx = context or get_context()

self._setup_queues()

self._taskqueue = queue.SimpleQueue()

self._cache = {}

self._state = RUN

self._maxtasksperchild = maxtasksperchild

self._initializer = initializer

self._initargs = initargs

if processes is None:

processes = os.cpu_count() or 1

if processes < 1:

raise ValueError("Number of processes must be at least 1")

if initializer is not None and not callable(initializer):

raise TypeError('initializer must be a callable')

self._processes = processes

self._pool = []

self._repopulate_pool()

self._worker_handler = threading.Thread(

target=Pool._handle_workers,

args=(self._cache, self._taskqueue, self._ctx, self.Process,

self._processes, self._pool, self._inqueue, self._outqueue,

self._initializer, self._initargs, self._maxtasksperchild,

self._wrap_exception)

)

self._worker_handler.daemon = True

self._worker_handler._state = RUN

self._worker_handler.start()

self._task_handler = threading.Thread(

target=Pool._handle_tasks,

args=(self._taskqueue, self._quick_put, self._outqueue,

self._pool, self._cache)

)

self._task_handler.daemon = True

self._task_handler._state = RUN

self._task_handler.start()

self._result_handler = threading.Thread(

target=Pool._handle_results,

args=(self._outqueue, self._quick_get, self._cache)

)

self._result_handler.daemon = True

self._result_handler._state = RUN

self._result_handler.start()

self._terminate = util.Finalize(

self, self._terminate_pool,

args=(self._taskqueue, self._inqueue, self._outqueue, self._pool,

self._worker_handler, self._task_handler,

self._result_handler, self._cache),

exitpriority=15

)

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值