summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorRaymond Hettinger <python@rcn.com>2010-09-02 09:44:28 +0000
committerRaymond Hettinger <python@rcn.com>2010-09-02 09:44:28 +0000
commit38d17e3df030e443653b8999a2e3ccf12968c9ae (patch)
treef96308bd8939a4bc9eef6cbf7beb33f56a8563eb
parentccb90e3ccd60bc0156905510074dce84e5b1272c (diff)
downloadcpython-git-38d17e3df030e443653b8999a2e3ccf12968c9ae.tar.gz
Speed-up cache updates
-rw-r--r--Lib/collections.py13
-rw-r--r--Lib/functools.py3
2 files changed, 14 insertions, 2 deletions
diff --git a/Lib/collections.py b/Lib/collections.py
index 1a43afbe89..6daa5967c1 100644
--- a/Lib/collections.py
+++ b/Lib/collections.py
@@ -161,6 +161,19 @@ class OrderedDict(dict, MutableMapping):
def __del__(self):
self.clear() # eliminate cyclical references
+ def _move_to_end(self, key, PREV=0, NEXT=1):
+ 'Fast version of self[key]=self.pop(key). Private method for internal use.'
+ link = self.__map[key]
+ link_prev = link[PREV]
+ link_next = link[NEXT]
+ link_prev[NEXT] = link_next
+ link_next[PREV] = link_prev
+ root = self.__root
+ last = root[PREV]
+ link[PREV] = last
+ link[NEXT] = root
+ last[NEXT] = root[PREV] = link
+
################################################################################
### namedtuple
diff --git a/Lib/functools.py b/Lib/functools.py
index 1bbc520e7c..f9e35d857a 100644
--- a/Lib/functools.py
+++ b/Lib/functools.py
@@ -139,8 +139,7 @@ def lru_cache(maxsize=100):
try:
with lock:
result = cache[key]
- del cache[key]
- cache[key] = result # record recent use of this key
+ cache._move_to_end(key) # record recent use of this key
wrapper.hits += 1
except KeyError:
result = user_function(*args, **kwds)