py里缓存(lru_catch)的简单了解
作者:互联网
2026-04-11
缓存的了解
当我们在进行一些重复的计算时,可以适当的引入缓存如lru_cache来减少计算的时间,提高相应速率,
示例代码
@lru.cache(maxsize=3)
def test(n:num)->int:
print(f"正在计算{n}")
return n * n
test(1)
test(1)
test(2)
test(3)
代码执行结果
通过执行结果发现 我们在执行第二个test(1)的时候,似乎并没执行内部逻辑如打印 :正在计算... ,而是直接就返回了结果,但是后面的test(2) 和 test(3) 又有执行内部逻辑
结论
1、缓存原理
1-1缓存key
每次你调用test(n)时,lru_cache都是将参数作为缓存的key,然后他会检查是否之前已经计算过这个n对应的结果
1-2缓存值
对应n的结果 会被存储在缓存中 ,当相同的key被调用时,lru_cache会直接返回缓存的结果
1-3缓存淘汰机制
maxsize=3,指定了最多缓存3个,当超过时,最早的缓存的结果会被丢弃
相关推荐
专题
+ 收藏
+ 收藏
+ 收藏
+ 收藏
+ 收藏
+ 收藏
最新数据
相关文章
Laravel13 + Vue3 的免费可商用 PHP 管理后台 CatchAdmin V5.2.0 发布
04/13
Python的管道符(|)联合类型语法糖
04/12
python win32COM 对象介绍调用Word、WPS 与应用生态
04/12
【Shopee Games 年终盛典技术揭秘】用 CLIP + 大模型 为 2 亿用户生成专属动漫形象
04/12
Python空值判断避坑指南 + 图片定点缩放逻辑优化实战
04/12
VectorStoreRetriever 三种搜索类型
04/12
Scikit-learn 零基础,从安装到实战机器学习模型
04/12
一文助你了解Langchain
04/12
Fastapi中的 lifespan
04/12
LangChain1.0 实现 PDF 文档向量检索全流程
04/12
AI精选
