diff options
author | INADA Naoki <methane@users.noreply.github.com> | 2018-01-20 00:54:42 (GMT) |
---|---|---|
committer | GitHub <noreply@github.com> | 2018-01-20 00:54:42 (GMT) |
commit | 6690bb9f17d34eb3dec0aca8919d8d27d6c3c452 (patch) | |
tree | fb237c82733daa1c4536ad8a93253f413adbeca3 | |
parent | 338cd83c5dceaed785f5bf613e2122f871908e2a (diff) | |
download | cpython-6690bb9f17d34eb3dec0aca8919d8d27d6c3c452.zip cpython-6690bb9f17d34eb3dec0aca8919d8d27d6c3c452.tar.gz cpython-6690bb9f17d34eb3dec0aca8919d8d27d6c3c452.tar.bz2 |
bpo-32596: Lazy import concurrent.futures.process and thread (GH-5241)
-rw-r--r-- | Lib/concurrent/futures/__init__.py | 35 | ||||
-rw-r--r-- | Misc/NEWS.d/next/Library/2018-01-19-19-57-45.bpo-32596.4aVIie.rst | 4 |
2 files changed, 37 insertions, 2 deletions
diff --git a/Lib/concurrent/futures/__init__.py b/Lib/concurrent/futures/__init__.py index ba8de16..72aca81 100644 --- a/Lib/concurrent/futures/__init__.py +++ b/Lib/concurrent/futures/__init__.py @@ -15,5 +15,36 @@ from concurrent.futures._base import (FIRST_COMPLETED, Executor, wait, as_completed) -from concurrent.futures.process import ProcessPoolExecutor -from concurrent.futures.thread import ThreadPoolExecutor + +__all__ = ( + 'FIRST_COMPLETED', + 'FIRST_EXCEPTION', + 'ALL_COMPLETED', + 'CancelledError', + 'TimeoutError', + 'BrokenExecutor', + 'Future', + 'Executor', + 'wait', + 'as_completed', + 'ProcessPoolExecutor', + 'ThreadPoolExecutor', +) + + +def __dir__(): + return __all__ + ('__author__', '__doc__') + + +def __getattr__(name): + global ProcessPoolExecutor, ThreadPoolExecutor + + if name == 'ProcessPoolExecutor': + from .process import ProcessPoolExecutor + return ProcessPoolExecutor + + if name == 'ThreadPoolExecutor': + from .thread import ThreadPoolExecutor + return ThreadPoolExecutor + + raise AttributeError(f"module {__name__} has no attribute {name}") diff --git a/Misc/NEWS.d/next/Library/2018-01-19-19-57-45.bpo-32596.4aVIie.rst b/Misc/NEWS.d/next/Library/2018-01-19-19-57-45.bpo-32596.4aVIie.rst new file mode 100644 index 0000000..a90f7d1 --- /dev/null +++ b/Misc/NEWS.d/next/Library/2018-01-19-19-57-45.bpo-32596.4aVIie.rst @@ -0,0 +1,4 @@ +``concurrent.futures`` imports ``ThreadPoolExecutor`` and +``ProcessPoolExecutor`` lazily (using :pep:`562`). +It makes ``import asyncio`` about 15% faster because asyncio +uses only ``ThreadPoolExecutor`` by default. |