0

0

Python如何实现缓存?提升程序效率方法

星夢妙者

星夢妙者

发布时间:2025-07-23 09:45:41

|

760人浏览过

|

来源于php中文网

原创

python实现缓存的核心在于通过空间换时间提升效率,具体方法包括:1.使用字典存储计算结果,优点是简单易懂但存在内存溢出和冲突风险;2.使用functools.lru_cache装饰器,自动管理缓存大小,适合参数可哈希的场景;3.使用cachetools库,支持多种缓存算法但使用较复杂;4.使用redis或memcached实现分布式缓存,适合大数据量和分布式部署但需额外维护。选择策略应根据需求权衡,同时注意处理缓存失效、雪崩、击穿和穿透问题以保障系统稳定性。

Python如何实现缓存?提升程序效率方法

Python实现缓存,本质上就是在时间和空间上做权衡,用空间换时间,避免重复计算,提升程序运行效率。简单来说,就是把计算结果存起来,下次再用的时候直接拿,不用重新算。

Python如何实现缓存?提升程序效率方法

解决方案

Python实现缓存的方法有很多种,从简单的字典到复杂的第三方库,可以根据实际需求选择。

  1. 使用字典 (Dictionary) 作为缓存:

    立即学习Python免费学习笔记(深入)”;

    Python如何实现缓存?提升程序效率方法

    这是最简单的一种方式。用一个字典来存储已经计算过的结果,key是输入参数,value是对应的结果。

    cache = {}
    
    def fibonacci(n):
        if n in cache:
            return cache[n]
        if n <= 1:
            result = n
        else:
            result = fibonacci(n-1) + fibonacci(n-2)
        cache[n] = result
        return result
    
    print(fibonacci(10)) # 输出: 55
    print(fibonacci(10)) # 输出: 55 (直接从缓存读取)

    这种方法的优点是简单易懂,缺点是缓存大小没有限制,可能会导致内存溢出。而且,这种缓存是全局的,多个函数之间共享可能会导致冲突。

    Python如何实现缓存?提升程序效率方法
  2. 使用 functools.lru_cache 装饰器:

    functools.lru_cache 是 Python 内置的缓存装饰器,可以自动缓存函数的结果。它使用 LRU (Least Recently Used) 算法来淘汰缓存中的数据,可以限制缓存的大小。

    from functools import lru_cache
    
    @lru_cache(maxsize=128) # 设置缓存最大大小为128
    def fibonacci(n):
        if n <= 1:
            return n
        return fibonacci(n-1) + fibonacci(n-2)
    
    print(fibonacci(10)) # 输出: 55
    print(fibonacci(10)) # 输出: 55 (直接从缓存读取)
    print(fibonacci.cache_info()) # 查看缓存信息

    lru_cache 的优点是使用简单,功能强大,可以自动管理缓存的大小。缺点是只能缓存函数的参数和返回值都是可哈希的类型。

  3. 使用第三方缓存库 (例如 cachetools):

    无限画
    无限画

    千库网旗下AI绘画创作平台

    下载

    cachetools 是一个功能更强大的缓存库,提供了多种缓存算法,例如 LRU, LFU (Least Frequently Used), MRU (Most Recently Used) 等。

    import cachetools
    
    cache = cachetools.LRUCache(maxsize=128)
    
    def fibonacci(n):
        if n in cache:
            return cache[n]
        if n <= 1:
            result = n
        else:
            result = fibonacci(n-1) + fibonacci(n-2)
        cache[n] = result
        return result
    
    print(fibonacci(10)) # 输出: 55
    print(fibonacci(10)) # 输出: 55 (直接从缓存读取)
    print(cache.currsize) # 查看当前缓存大小

    cachetools 的优点是灵活性高,可以根据实际需求选择不同的缓存算法。缺点是使用起来稍微复杂一些。

  4. 使用 Redis 或 Memcached 作为分布式缓存:

    如果程序是分布式部署的,或者需要缓存的数据量很大,可以考虑使用 Redis 或 Memcached 作为分布式缓存。这些缓存系统可以将数据存储在内存中,并提供快速的读写速度。

    import redis
    
    r = redis.Redis(host='localhost', port=6379, db=0)
    
    def fibonacci(n):
        key = f"fibonacci:{n}"
        result = r.get(key)
        if result:
            return int(result)
        if n <= 1:
            result = n
        else:
            result = fibonacci(n-1) + fibonacci(n-2)
        r.set(key, result)
        return result
    
    print(fibonacci(10)) # 输出: 55
    print(fibonacci(10)) # 输出: 55 (直接从缓存读取)

    使用 Redis 或 Memcached 的优点是缓存容量大,可以支持分布式部署。缺点是需要额外的部署和维护成本。

如何选择合适的缓存策略?

选择合适的缓存策略取决于你的具体需求。如果只是简单的函数缓存,functools.lru_cache 通常就足够了。如果需要更复杂的缓存策略,或者需要分布式缓存,可以考虑使用 cachetools、Redis 或 Memcached。

缓存失效策略有哪些?如何选择?

缓存失效策略决定了何时从缓存中移除数据。常见的策略包括:

  • TTL (Time To Live): 设置缓存的过期时间,超过时间后自动失效。适用于数据有时间限制的场景。
  • LRU (Least Recently Used): 移除最近最少使用的数据。适用于数据访问频率不均匀的场景。
  • LFU (Least Frequently Used): 移除使用频率最低的数据。适用于需要保留常用数据的场景。
  • 手动失效: 通过代码手动移除缓存中的数据。适用于需要精确控制缓存失效的场景。

选择哪种策略取决于数据的特点和业务需求。例如,对于经常变化的数据,应该使用较短的 TTL。对于不经常变化的数据,可以使用 LRU 或 LFU。

缓存雪崩、击穿和穿透是什么?如何避免?

这三个是缓存常见的并发问题,理解它们有助于更好地使用缓存:

  • 缓存雪崩: 大量缓存同时失效,导致请求直接打到数据库,造成数据库压力过大甚至崩溃。
    • 避免方法: 设置不同的过期时间,避免同时失效;使用互斥锁,保证只有一个请求打到数据库;使用熔断降级策略,保护数据库。
  • 缓存击穿: 某个热点数据缓存失效,导致大量请求打到数据库。
    • 避免方法: 设置永不过期的热点数据;使用互斥锁,保证只有一个请求打到数据库;预热缓存,提前将热点数据加载到缓存中。
  • 缓存穿透: 请求的数据在缓存和数据库中都不存在,导致每次请求都打到数据库。
    • 避免方法: 缓存空对象,将不存在的数据也缓存起来;使用布隆过滤器,快速判断数据是否存在;限制非法请求,防止恶意攻击。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

WorkBuddy
WorkBuddy

腾讯云推出的AI原生桌面智能体工作台

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
什么是分布式
什么是分布式

分布式是一种计算和数据处理的方式,将计算任务或数据分散到多个计算机或节点中进行处理。本专题为大家提供分布式相关的文章、下载、课程内容,供大家免费下载体验。

411

2023.08.11

分布式和微服务的区别
分布式和微服务的区别

分布式和微服务的区别在定义和概念、设计思想、粒度和复杂性、服务边界和自治性、技术栈和部署方式等。本专题为大家提供分布式和微服务相关的文章、下载、课程内容,供大家免费下载体验。

251

2023.10.07

页面置换算法
页面置换算法

页面置换算法是操作系统中用来决定在内存中哪些页面应该被换出以便为新的页面提供空间的算法。本专题为大家提供页面置换算法的相关文章,大家可以免费体验。

500

2023.08.14

常用的数据库软件
常用的数据库软件

常用的数据库软件有MySQL、Oracle、SQL Server、PostgreSQL、MongoDB、Redis、Cassandra、Hadoop、Spark和Amazon DynamoDB。更多关于数据库软件的内容详情请看本专题下面的文章。php中文网欢迎大家前来学习。

1007

2023.11.02

内存数据库有哪些
内存数据库有哪些

内存数据库有Redis、Memcached、Apache Ignite、VoltDB、TimesTen、H2 Database、Aerospike、Oracle TimesTen In-Memory Database、SAP HANA和ache Cassandra。更多关于内存数据库相关问题,详情请看本专题下面的文章。php中文网欢迎大家前来学习。

673

2023.11.14

mongodb和redis哪个读取速度快
mongodb和redis哪个读取速度快

redis 的读取速度比 mongodb 更快。原因包括:1. redis 使用简单的键值存储,而 mongodb 存储 json 格式的数据,需要解析和反序列化。2. redis 使用哈希表快速查找数据,而 mongodb 使用 b-tree 索引。因此,redis 在需要高性能读取操作的应用程序中是一个更好的选择。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

501

2024.04.02

redis怎么做缓存服务器
redis怎么做缓存服务器

redis 作为缓存服务器的答案:redis 是一款开源、高性能、分布式的键值存储,可作为缓存服务器使用。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

413

2024.04.07

redis怎么解决数据一致性
redis怎么解决数据一致性

redis 提供了两种一致性模型,以维护副本数据一致性:强一致性 (sync) 确保写操作仅在复制到所有从节点后才完成;最终一致性 (async) 则在主节点上写操作后认为已完成,牺牲一致性换取性能。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

408

2024.04.07

TypeScript类型系统进阶与大型前端项目实践
TypeScript类型系统进阶与大型前端项目实践

本专题围绕 TypeScript 在大型前端项目中的应用展开,深入讲解类型系统设计与工程化开发方法。内容包括泛型与高级类型、类型推断机制、声明文件编写、模块化结构设计以及代码规范管理。通过真实项目案例分析,帮助开发者构建类型安全、结构清晰、易维护的前端工程体系,提高团队协作效率与代码质量。

26

2026.03.13

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
PHP课程
PHP课程

共137课时 | 13.5万人学习

Go语言实战之 GraphQL
Go语言实战之 GraphQL

共10课时 | 0.9万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号