diff options
| author | Raymond Hettinger <python@rcn.com> | 2013-03-10 17:57:28 -0700 | 
|---|---|---|
| committer | Raymond Hettinger <python@rcn.com> | 2013-03-10 17:57:28 -0700 | 
| commit | ec4b174de4177298c1421786764170cc62f9b748 (patch) | |
| tree | 39c324d9fd408ce3ea0d96fbd6dd1bee4cb9d255 /Lib/threading.py | |
| parent | 720da571590427a10bbf04cdfe486f4ab6d85156 (diff) | |
| download | cpython-git-ec4b174de4177298c1421786764170cc62f9b748.tar.gz | |
Issue #17385: Fix quadratic behavior in threading.Condition
Diffstat (limited to 'Lib/threading.py')
| -rw-r--r-- | Lib/threading.py | 10 | 
1 files changed, 8 insertions, 2 deletions
| diff --git a/Lib/threading.py b/Lib/threading.py index 35d2e8a552..0261ee2706 100644 --- a/Lib/threading.py +++ b/Lib/threading.py @@ -10,6 +10,12 @@ except ImportError:      from time import time as _time  from traceback import format_exc as _format_exc  from _weakrefset import WeakSet +try: +    from _itertools import islice as _slice +    from _collections import deque as _deque +except ImportError: +    from itertools import islice as _islice +    from collections import deque as _deque  # Note regarding PEP 8 compliant names  #  This threading model was originally inspired by Java, and inherited @@ -146,7 +152,7 @@ class Condition:              self._is_owned = lock._is_owned          except AttributeError:              pass -        self._waiters = [] +        self._waiters = _deque()      def __enter__(self):          return self._lock.__enter__() @@ -217,7 +223,7 @@ class Condition:          if not self._is_owned():              raise RuntimeError("cannot notify on un-acquired lock")          __waiters = self._waiters -        waiters = __waiters[:n] +        waiters = _deque(_islice(__waiters, n))          if not waiters:              return          for waiter in waiters: | 
