from functools import _make_key
print(_make_key((4, 5), {}, False))
print(_make_key((4, 5), {}, True))
print(_make_key((4,), {'y':5}, False))
print(_make_key((), {'x':4, 'y':5}, False))
print(_make_key((), {'y':5, 'x':4}, False))
@lru_cache
def fib(n):
return 1 if n < 3 else fib(n-1) + fib(n-2)
# 斐波那契数列递归版本
fib(101)
# 一下就算出了斐波那契数列的第101项
# 返回结果:573147844013817084101
1.频繁使用
2.每一次获取代价高
3.一定时间内,每一次同样输入获得同样的结果,幂等性。
压力大
预热
lru_cache装饰器应用
学习lru_cache可以让我们了解缓存背后的原理。
from functools import lru_cache
# 导入funtools模块下的lru_cache
lru_cache?
Least-recently-used cache decorator.
缓存和命中必须相关,否则要缓存有什么用?
缓存:缓存满了后,要干掉,最近最少使用的数据
缓冲:服务器处理不了海量数据,先进缓冲,缓冲是先进先出原则
import time
def add(x, y):
print('--------')
time.sleep(2)
return x + y
# 没有缓存的版本
add(4, 5)
# 每次执行都休眠2秒
# 返回结果:--------
# 返回结果:9
@lru_cache
def add(x, y):
print('--------')
time.sleep(2)
return x + y
# 缓存版本
add(4, 5)
# 加了lru_cache后第一次运行也是2秒
# 返回结果:--------
# 返回结果:9
add(4, 5)
# 第2次命中缓存,直接给值
# 返回结果:9