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


Python futures.Future方法代碼示例

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


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

示例1: set_exc_info

# 需要導入模塊: from concurrent import futures [as 別名]
# 或者: from concurrent.futures import Future [as 別名]
def set_exc_info(self, exc_info):
        """Sets the exception information of a ``Future.``

        Preserves tracebacks on Python 2.

        .. versionadded:: 4.0
        """
        self._exc_info = exc_info
        self._log_traceback = True
        if not _GC_CYCLE_FINALIZERS:
            self._tb_logger = _TracebackLogger(exc_info)

        try:
            self._set_done()
        finally:
            # Activate the logger after all callbacks have had a
            # chance to call result() or exception().
            if self._log_traceback and self._tb_logger is not None:
                self._tb_logger.activate()
        self._exc_info = exc_info 
開發者ID:tao12345666333,項目名稱:tornado-zh,代碼行數:22,代碼來源:concurrent.py

示例2: future_set_exception_unless_cancelled

# 需要導入模塊: from concurrent import futures [as 別名]
# 或者: from concurrent.futures import Future [as 別名]
def future_set_exception_unless_cancelled(
    future: "Union[futures.Future[_T], Future[_T]]", exc: BaseException
) -> None:
    """Set the given ``exc`` as the `Future`'s exception.

    If the Future is already canceled, logs the exception instead. If
    this logging is not desired, the caller should explicitly check
    the state of the Future and call ``Future.set_exception`` instead of
    this wrapper.

    Avoids ``asyncio.InvalidStateError`` when calling ``set_exception()`` on
    a cancelled `asyncio.Future`.

    .. versionadded:: 6.0

    """
    if not future.cancelled():
        future.set_exception(exc)
    else:
        app_log.error("Exception after Future was cancelled", exc_info=exc) 
開發者ID:opendevops-cn,項目名稱:opendevops,代碼行數:22,代碼來源:concurrent.py

示例3: future_set_exc_info

# 需要導入模塊: from concurrent import futures [as 別名]
# 或者: from concurrent.futures import Future [as 別名]
def future_set_exc_info(
    future: "Union[futures.Future[_T], Future[_T]]",
    exc_info: Tuple[
        Optional[type], Optional[BaseException], Optional[types.TracebackType]
    ],
) -> None:
    """Set the given ``exc_info`` as the `Future`'s exception.

    Understands both `asyncio.Future` and the extensions in older
    versions of Tornado to enable better tracebacks on Python 2.

    .. versionadded:: 5.0

    .. versionchanged:: 6.0

       If the future is already cancelled, this function is a no-op.
       (previously ``asyncio.InvalidStateError`` would be raised)

    """
    if exc_info[1] is None:
        raise Exception("future_set_exc_info called with no exception")
    future_set_exception_unless_cancelled(future, exc_info[1]) 
開發者ID:opendevops-cn,項目名稱:opendevops,代碼行數:24,代碼來源:concurrent.py

示例4: future_add_done_callback

# 需要導入模塊: from concurrent import futures [as 別名]
# 或者: from concurrent.futures import Future [as 別名]
def future_add_done_callback(  # noqa: F811
    future: "Union[futures.Future[_T], Future[_T]]", callback: Callable[..., None]
) -> None:
    """Arrange to call ``callback`` when ``future`` is complete.

    ``callback`` is invoked with one argument, the ``future``.

    If ``future`` is already done, ``callback`` is invoked immediately.
    This may differ from the behavior of ``Future.add_done_callback``,
    which makes no such guarantee.

    .. versionadded:: 5.0
    """
    if future.done():
        callback(future)
    else:
        future.add_done_callback(callback) 
開發者ID:opendevops-cn,項目名稱:opendevops,代碼行數:19,代碼來源:concurrent.py

示例5: fetch_all_topics

# 需要導入模塊: from concurrent import futures [as 別名]
# 或者: from concurrent.futures import Future [as 別名]
def fetch_all_topics(self, workers: int) -> None:
        """
        Distribute stream ids across threads in order to fetch
        topics concurrently.
        """
        with ThreadPoolExecutor(max_workers=workers) as executor:
            list_of_streams = list(self.stream_dict.keys())
            thread_objects = {
                i: executor.submit(self.get_topics_in_stream,
                                   list_of_streams[i::workers])
                for i in range(workers)
            }  # type: Dict[int, Future[str]]
            wait(thread_objects.values())

        results = {
            str(name): self.exception_safe_result(thread_object)
            for name, thread_object in thread_objects.items()
        }  # type: Dict[str, str]
        if any(results.values()):
            failures = ['fetch_topics[{}]'.format(name)
                        for name, result in results.items()
                        if result]
            raise ServerConnectionFailure(", ".join(failures)) 
開發者ID:zulip,項目名稱:zulip-terminal,代碼行數:25,代碼來源:model.py

示例6: download_file

# 需要導入模塊: from concurrent import futures [as 別名]
# 或者: from concurrent.futures import Future [as 別名]
def download_file(self, media_item: DatabaseMedia, media_json: dict):
        """ farms a single media download off to the thread pool.

        Uses a dictionary of Futures -> mediaItem to track downloads that are
        currently scheduled/running. When a Future is done it calls
        do_download_complete to remove the Future from the dictionary and
        complete processing of the media item.
        """
        base_url = media_json["baseUrl"]

        # we dont want a massive queue so wait until at least one thread is free
        while len(self.pool_future_to_media) >= self.max_threads:
            # check which futures are done, complete the main thread work
            # and remove them from the dictionary
            done_list = []
            for future in self.pool_future_to_media.keys():
                if future.done():
                    done_list.append(future)

            self.do_download_complete(done_list)

        # start a new background download
        self.files_download_started += 1
        log.info(
            "downloading %d %s", self.files_download_started, media_item.relative_path
        )
        future = self.download_pool.submit(self.do_download_file, base_url, media_item)
        self.pool_future_to_media[future] = media_item 
開發者ID:gilesknap,項目名稱:gphotos-sync,代碼行數:30,代碼來源:GooglePhotosDownload.py

示例7: result_for_completed_scan_jobs

# 需要導入模塊: from concurrent import futures [as 別名]
# 或者: from concurrent.futures import Future [as 別名]
def result_for_completed_scan_jobs(
        cls, server_info: ServerConnectivityInfo, completed_scan_jobs: List[Future]
    ) -> ScanCommandResult:
        if len(completed_scan_jobs) != cls._scan_jobs_count:
            raise AssertionError("Did not receive all the scan jobs that needed to be completed")

        return cls.result_cls(results_field=[future.result() for future in completed_scan_jobs])  # type: ignore 
開發者ID:nabla-c0d3,項目名稱:sslyze,代碼行數:9,代碼來源:mock_plugins.py

示例8: all_queued_scan_jobs

# 需要導入模塊: from concurrent import futures [as 別名]
# 或者: from concurrent.futures import Future [as 別名]
def all_queued_scan_jobs(self) -> Set[Future]:
        all_queued_scan_jobs = set()
        for scan_jobs in self.queued_scan_jobs_per_scan_command.values():
            all_queued_scan_jobs.update(scan_jobs)
        return all_queued_scan_jobs 
開發者ID:nabla-c0d3,項目名稱:sslyze,代碼行數:7,代碼來源:scanner.py

示例9: _shutdown_thread_pools

# 需要導入模塊: from concurrent import futures [as 別名]
# 或者: from concurrent.futures import Future [as 別名]
def _shutdown_thread_pools(self) -> None:
        self._queued_server_scans = []
        for thread_pool in self._thread_pools:
            thread_pool.shutdown(wait=True)
        self._thread_pools = []

        # Force garbage collection because for some reason the Future objects created by ThreadPoolExecutor.submit()
        # take a ton of memory (compared to what they do - holding a function to call and its arguments):
        # https://stackoverflow.com/questions/45946274/rss-memory-usage-from-concurrent-futures
        # https://stackoverflow.com/questions/53104082/using-threadpoolexecutor-with-reduced-memory-footprint
        # https://stackoverflow.com/questions/34770169/using-concurrent-futures-without-running-out-of-ram
        # We force garbage collection here to ensure memory usage does not balloon when running SSLyze in some kind
        # of long-running app (such as a web app). Otherwise, the GC tends to not cleanup all the Future objects right
        # away (although at this point, all the work has been completed) and memory usage goes up like crazy
        gc.collect() 
開發者ID:nabla-c0d3,項目名稱:sslyze,代碼行數:17,代碼來源:scanner.py

示例10: result_for_completed_scan_jobs

# 需要導入模塊: from concurrent import futures [as 別名]
# 或者: from concurrent.futures import Future [as 別名]
def result_for_completed_scan_jobs(
        cls, server_info: "ServerConnectivityInfo", completed_scan_jobs: List[Future]
    ) -> _ScanCommandResultTypeVar:
        """Transform the completed scan jobs for a given scan command into a result.
        """
        pass 
開發者ID:nabla-c0d3,項目名稱:sslyze,代碼行數:8,代碼來源:plugin_base.py

示例11: __del__

# 需要導入模塊: from concurrent import futures [as 別名]
# 或者: from concurrent.futures import Future [as 別名]
def __del__(self):
        if self.formatted_tb:
            app_log.error('Future exception was never retrieved: %s',
                          ''.join(self.formatted_tb).rstrip()) 
開發者ID:tao12345666333,項目名稱:tornado-zh,代碼行數:6,代碼來源:concurrent.py

示例12: result

# 需要導入模塊: from concurrent import futures [as 別名]
# 或者: from concurrent.futures import Future [as 別名]
def result(self, timeout=None):
        """If the operation succeeded, return its result.  If it failed,
        re-raise its exception.

        This method takes a ``timeout`` argument for compatibility with
        `concurrent.futures.Future` but it is an error to call it
        before the `Future` is done, so the ``timeout`` is never used.
        """
        self._clear_tb_log()
        if self._result is not None:
            return self._result
        if self._exc_info is not None:
            raise_exc_info(self._exc_info)
        self._check_done()
        return self._result 
開發者ID:tao12345666333,項目名稱:tornado-zh,代碼行數:17,代碼來源:concurrent.py

示例13: exception

# 需要導入模塊: from concurrent import futures [as 別名]
# 或者: from concurrent.futures import Future [as 別名]
def exception(self, timeout=None):
        """If the operation raised an exception, return the `Exception`
        object.  Otherwise returns None.

        This method takes a ``timeout`` argument for compatibility with
        `concurrent.futures.Future` but it is an error to call it
        before the `Future` is done, so the ``timeout`` is never used.
        """
        self._clear_tb_log()
        if self._exc_info is not None:
            return self._exc_info[1]
        else:
            self._check_done()
            return None 
開發者ID:tao12345666333,項目名稱:tornado-zh,代碼行數:16,代碼來源:concurrent.py

示例14: add_done_callback

# 需要導入模塊: from concurrent import futures [as 別名]
# 或者: from concurrent.futures import Future [as 別名]
def add_done_callback(self, fn):
        """Attaches the given callback to the `Future`.

        It will be invoked with the `Future` as its argument when the Future
        has finished running and its result is available.  In Tornado
        consider using `.IOLoop.add_future` instead of calling
        `add_done_callback` directly.
        """
        if self._done:
            fn(self)
        else:
            self._callbacks.append(fn) 
開發者ID:tao12345666333,項目名稱:tornado-zh,代碼行數:14,代碼來源:concurrent.py

示例15: set_result

# 需要導入模塊: from concurrent import futures [as 別名]
# 或者: from concurrent.futures import Future [as 別名]
def set_result(self, result):
        """Sets the result of a ``Future``.

        It is undefined to call any of the ``set`` methods more than once
        on the same object.
        """
        self._result = result
        self._set_done() 
開發者ID:tao12345666333,項目名稱:tornado-zh,代碼行數:10,代碼來源:concurrent.py


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