From: Raymond Hettinger Date: Fri, 18 Mar 2011 22:09:10 +0000 (-0700) Subject: Minor optimization -- factor a constant expression out of the inner-loop. X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=7e4c168385b5f723dbeb340abe51f7b99399e1c7;p=python Minor optimization -- factor a constant expression out of the inner-loop. --- diff --git a/Lib/functools.py b/Lib/functools.py index 03de69ae16..fdc9c79098 100644 --- a/Lib/functools.py +++ b/Lib/functools.py @@ -140,7 +140,7 @@ def lru_cache(maxsize=100): tuple=tuple, sorted=sorted, len=len, KeyError=KeyError): hits = misses = 0 - kwd_mark = object() # separates positional and keyword args + kwd_mark = (object(),) # separates positional and keyword args lock = Lock() # needed because ordereddicts aren't threadsafe if maxsize is None: @@ -151,7 +151,7 @@ def lru_cache(maxsize=100): nonlocal hits, misses key = args if kwds: - key += (kwd_mark,) + tuple(sorted(kwds.items())) + key += kwd_mark + tuple(sorted(kwds.items())) try: result = cache[key] hits += 1 @@ -170,7 +170,7 @@ def lru_cache(maxsize=100): nonlocal hits, misses key = args if kwds: - key += (kwd_mark,) + tuple(sorted(kwds.items())) + key += kwd_mark + tuple(sorted(kwds.items())) try: with lock: result = cache[key]