當前位置: 首頁>>代碼示例>>Python>>正文


Python futures.FIRST_COMPLETED屬性代碼示例

本文整理匯總了Python中concurrent.futures.FIRST_COMPLETED屬性的典型用法代碼示例。如果您正苦於以下問題:Python futures.FIRST_COMPLETED屬性的具體用法?Python futures.FIRST_COMPLETED怎麽用?Python futures.FIRST_COMPLETED使用的例子?那麽, 這裏精選的屬性代碼示例或許可以為您提供幫助。您也可以進一步了解該屬性所在concurrent.futures的用法示例。


在下文中一共展示了futures.FIRST_COMPLETED屬性的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。

示例1: perform_requests

# 需要導入模塊: from concurrent import futures [as 別名]
# 或者: from concurrent.futures import FIRST_COMPLETED [as 別名]
def perform_requests(self):
        signal.signal(signal.SIGINT, self.exit_fast)
        signal.signal(signal.SIGTERM, self.exit_fast)

        self.state = b'E'
        for q_batch in self.get_batch():
            for (_, _) in self.split_batch(q_batch):
                if self.state != b"R":
                    self.state = b'R'
                yield
                continue

        #  wait for all batches to finish before returning
        self.state = b'W'
        while self.futures:
            f_len = len(self.futures)
            self.futures = [i for i in self.futures if not i.done()]
            if f_len != len(self.futures):
                self.ui.debug('Waiting for final requests to finish. '
                              'remaining requests: {}'
                              ''.format(len(self.futures)))
            wait(self.futures, return_when=FIRST_COMPLETED)
        self.state = b'D'
        yield True 
開發者ID:datarobot,項目名稱:batch-scoring,代碼行數:26,代碼來源:dry_run.py

示例2: _get_layers

# 需要導入模塊: from concurrent import futures [as 別名]
# 或者: from concurrent.futures import FIRST_COMPLETED [as 別名]
def _get_layers(self):
        """
        Wait for renderers to produce new layers, yields until at least one
        layer is active.
        """
        # schedule tasks to wait on each renderer queue
        for r_idx, _ in enumerate(self.layers):
            if _.waiter is None or _.waiter.done():
                _.waiter = ensure_future(self._dequeue(r_idx))

        # async wait for at least one completion
        waiters = [layer.waiter for layer in self.layers]
        if not waiters:
            return

        await asyncio.wait(waiters, return_when=futures.FIRST_COMPLETED)

        # check the rest without waiting
        for r_idx, _ in enumerate(self.layers):
            if _.waiter is not None and not _.waiter.done():
                self._dequeue_nowait(r_idx) 
開發者ID:cyanogen,項目名稱:uchroma,代碼行數:23,代碼來源:anim.py

示例3: _create_and_install_waiters

# 需要導入模塊: from concurrent import futures [as 別名]
# 或者: from concurrent.futures import FIRST_COMPLETED [as 別名]
def _create_and_install_waiters(fs, return_when):
        if return_when == _AS_COMPLETED:
            waiter = _AsCompletedWaiter()
        elif return_when == FIRST_COMPLETED:
            waiter = _FirstCompletedWaiter()
        else:
            pending_count = sum(
                    f._state not in [CANCELLED_AND_NOTIFIED, FINISHED]
                    for f in fs)

            if return_when == FIRST_EXCEPTION:
                waiter = _AllCompletedWaiter(pending_count,
                                             stop_on_exception=True)
            elif return_when == ALL_COMPLETED:
                waiter = _AllCompletedWaiter(pending_count,
                                             stop_on_exception=False)
            else:
                raise ValueError("Invalid return condition: %r" % return_when)

        for f in fs:
            f._waiters.append(waiter)

        return waiter 
開發者ID:joblib,項目名稱:loky,代碼行數:25,代碼來源:_base.py

示例4: _run

# 需要導入模塊: from concurrent import futures [as 別名]
# 或者: from concurrent.futures import FIRST_COMPLETED [as 別名]
def _run(self):
        first_completed = concurrent.FIRST_COMPLETED

        if self._get_max_tasks() < 1:
            raise RuntimeError("Executor has no workers")

        try:
            while not self.goal(self.learner):
                futures = self._get_futures()
                done, _ = concurrent.wait(futures, return_when=first_completed)
                self._process_futures(done)
        finally:
            remaining = self._remove_unfinished()
            if remaining:
                concurrent.wait(remaining)
            self._cleanup() 
開發者ID:python-adaptive,項目名稱:adaptive,代碼行數:18,代碼來源:runner.py

示例5: process

# 需要導入模塊: from concurrent import futures [as 別名]
# 或者: from concurrent.futures import FIRST_COMPLETED [as 別名]
def process(self, queue, workflow):
        while queue.__futures__:
            done, _ = wait(queue.__futures__, return_when=FIRST_COMPLETED)
            queue.progress(done)
        return workflow.result() 
開發者ID:vmagamedov,項目名稱:hiku,代碼行數:7,代碼來源:threads.py

示例6: start

# 需要導入模塊: from concurrent import futures [as 別名]
# 或者: from concurrent.futures import FIRST_COMPLETED [as 別名]
def start(self, jobs=None):
        """
        Engine starts to run jobs
        :param jobs: A list contains at least one job
        :return:
        """
        try:
            if not jobs:
                logger.warning("CloudConnectEngine just exits with no jobs to run")
                return
            for job in jobs:
                self._add_job(job)
            while not self._shutdown:
                logger.info("CloudConnectEngine starts to run...")
                if not self._pending_job_results:
                    logger.info("CloudConnectEngine has no more jobs to run")
                    break
                # check the intermediate results to find the done jobs and not
                # done jobs
                done_and_not_done_jobs = cf.wait(self._pending_job_results,
                                                 return_when=cf.FIRST_COMPLETED)
                self._pending_job_results = done_and_not_done_jobs.not_done
                done_job_results = done_and_not_done_jobs.done
                for future in done_job_results:
                    # get the result of each done jobs and add new jobs to the
                    # engine if the result spawns more jobs
                    result = future.result()
                    if result:
                        if isinstance(result, Iterable):
                            for temp in result:
                                self._add_job(temp)
                        else:
                            self._add_job(result)
        except:
            logger.exception("CloudConnectEngine encountered exception")
        finally:
            self._teardown() 
開發者ID:remg427,項目名稱:misp42splunk,代碼行數:39,代碼來源:engine_v2.py

示例7: wait_any_request

# 需要導入模塊: from concurrent import futures [as 別名]
# 或者: from concurrent.futures import FIRST_COMPLETED [as 別名]
def wait_any_request(requests, do_raise=False, timeout=None):
        if not AsyncArctic._wait_until_scheduled(requests, timeout):
            raise AsyncArcticException("Timed-out while waiting for request to be scheduled")
        while requests and not any(r.is_completed for r in requests):
            AsyncArctic.wait_tasks(tuple(r.future for r in requests if not r.is_completed and r.future is not None),
                                   timeout=timeout, return_when=FIRST_COMPLETED, raise_exceptions=do_raise) 
開發者ID:man-group,項目名稱:arctic,代碼行數:8,代碼來源:async_arctic.py

示例8: test_first_completed

# 需要導入模塊: from concurrent import futures [as 別名]
# 或者: from concurrent.futures import FIRST_COMPLETED [as 別名]
def test_first_completed(self):
        future1 = self.executor.submit(mul, 21, 2)
        future2 = self.executor.submit(time.sleep, 1.5)

        done, not_done = futures.wait(
                [CANCELLED_FUTURE, future1, future2],
                 return_when=futures.FIRST_COMPLETED)

        self.assertEqual(set([future1]), done)
        self.assertEqual(set([CANCELLED_FUTURE, future2]), not_done) 
開發者ID:Microvellum,項目名稱:Fluid-Designer,代碼行數:12,代碼來源:test_concurrent_futures.py

示例9: test_first_completed_some_already_completed

# 需要導入模塊: from concurrent import futures [as 別名]
# 或者: from concurrent.futures import FIRST_COMPLETED [as 別名]
def test_first_completed_some_already_completed(self):
        future1 = self.executor.submit(time.sleep, 1.5)

        finished, pending = futures.wait(
                 [CANCELLED_AND_NOTIFIED_FUTURE, SUCCESSFUL_FUTURE, future1],
                 return_when=futures.FIRST_COMPLETED)

        self.assertEqual(
                set([CANCELLED_AND_NOTIFIED_FUTURE, SUCCESSFUL_FUTURE]),
                finished)
        self.assertEqual(set([future1]), pending) 
開發者ID:Microvellum,項目名稱:Fluid-Designer,代碼行數:13,代碼來源:test_concurrent_futures.py

示例10: test_wait

# 需要導入模塊: from concurrent import futures [as 別名]
# 或者: from concurrent.futures import FIRST_COMPLETED [as 別名]
def test_wait(self):
        done, not_done = futures.wait([QUEUED_RESULT, FINISHED_RESULT],
                                      return_when=futures.FIRST_COMPLETED)
        self.assertEqual(set([FINISHED_RESULT]), done)
        self.assertEqual(set([QUEUED_RESULT]), not_done) 
開發者ID:civisanalytics,項目名稱:civis-python,代碼行數:7,代碼來源:test_polling.py

示例11: run

# 需要導入模塊: from concurrent import futures [as 別名]
# 或者: from concurrent.futures import FIRST_COMPLETED [as 別名]
def run(self):
        # init listeners, add them to the event loop
        for s in self.sockets:
            s.setblocking(False)
            self.poller.register(s, selectors.EVENT_READ, self.accept)

        timeout = self.cfg.timeout or 0.5

        while self.alive:
            # notify the arbiter we are alive
            self.notify()

            # can we accept more connections?
            if self.nr < self.worker_connections:
                # wait for an event
                events = self.poller.select(0.02)
                for key, mask in events:
                    callback = key.data
                    callback(key.fileobj)

            if not self.is_parent_alive():
                break

            # hanle keepalive timeouts
            self.murder_keepalived()

            # if the number of connections is < to the max we can handle at
            # the same time there is no need to wait for one
            if len(self.futures) < self.cfg.threads:
                continue

            result = futures.wait(self.futures, timeout=timeout,
                    return_when=futures.FIRST_COMPLETED)

            if not result.done:
                break
            else:
                [self.futures.remove(f) for f in result.done]

        self.tpool.shutdown(False)
        self.poller.close() 
開發者ID:chalasr,項目名稱:Flask-P2P,代碼行數:43,代碼來源:gthread.py

示例12: wait_for_any

# 需要導入模塊: from concurrent import futures [as 別名]
# 或者: from concurrent.futures import FIRST_COMPLETED [as 別名]
def wait_for_any(fs, timeout=None):
    """Wait for one (**any**) of the futures to complete.

    Works correctly with both green and non-green futures (but not both
    together, since this can't be guaranteed to avoid dead-lock due to how
    the waiting implementations are different when green threads are being
    used).

    Returns pair (done futures, not done futures).
    """
    return _wait_for(fs, futures.FIRST_COMPLETED, _wait_for_any_green,
                     'wait_for_any', timeout=timeout) 
開發者ID:openstack,項目名稱:futurist,代碼行數:14,代碼來源:waiters.py

示例13: __anext__

# 需要導入模塊: from concurrent import futures [as 別名]
# 或者: from concurrent.futures import FIRST_COMPLETED [as 別名]
def __anext__(self) -> Any:
        if self.is_closed:
            if not isasyncgen(self.iterator):
                raise StopAsyncIteration
            value = await self.iterator.__anext__()
            result = self.callback(value)

        else:
            aclose = ensure_future(self._close_event.wait())
            anext = ensure_future(self.iterator.__anext__())

            pending: Set[Future] = (
                await wait([aclose, anext], return_when=FIRST_COMPLETED)
            )[1]
            for task in pending:
                task.cancel()

            if aclose.done():
                raise StopAsyncIteration

            error = anext.exception()
            if error:
                if not self.reject_callback or isinstance(
                    error, (StopAsyncIteration, GeneratorExit)
                ):
                    raise error
                result = self.reject_callback(error)
            else:
                value = anext.result()
                result = self.callback(value)

        return await result if isawaitable(result) else result 
開發者ID:graphql-python,項目名稱:graphql-core,代碼行數:34,代碼來源:map_async_iterator.py

示例14: test_first_completed

# 需要導入模塊: from concurrent import futures [as 別名]
# 或者: from concurrent.futures import FIRST_COMPLETED [as 別名]
def test_first_completed(self):
        future1 = self.executor.submit(mul, 21, 2)
        future2 = self.executor.submit(time.sleep, 1.5)

        done, not_done = futures.wait([CANCELLED_FUTURE, future1, future2],
                                      return_when=futures.FIRST_COMPLETED)

        assert set([future1]) == done
        assert set([CANCELLED_FUTURE, future2]) == not_done 
開發者ID:joblib,項目名稱:loky,代碼行數:11,代碼來源:_test_process_executor.py

示例15: test_first_completed_some_already_completed

# 需要導入模塊: from concurrent import futures [as 別名]
# 或者: from concurrent.futures import FIRST_COMPLETED [as 別名]
def test_first_completed_some_already_completed(self):
        future1 = self.executor.submit(time.sleep, 1.5)

        finished, pending = futures.wait([CANCELLED_AND_NOTIFIED_FUTURE,
                                          SUCCESSFUL_FUTURE, future1],
                                         return_when=futures.FIRST_COMPLETED)

        assert (set([CANCELLED_AND_NOTIFIED_FUTURE, SUCCESSFUL_FUTURE]) ==
                finished)
        assert set([future1]) == pending 
開發者ID:joblib,項目名稱:loky,代碼行數:12,代碼來源:_test_process_executor.py


注:本文中的concurrent.futures.FIRST_COMPLETED屬性示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。