当前位置:
首页 > temp > python入门教程 >
-
计算速度太慢?试试 lru_cache 装饰器
众所周知,python语言是相当好用的,但是它的执行性能也是相对其他语言比较慢的。还好python提供了一个非常优秀的装饰器来解决这个问题,它就是lru_cache装饰器。lru_cache是通过著名的LCU算法来实现的,也就是最近最久未使用缓存淘汰算法。
为了形成明显的对比,使用普通的方式来实现一个函数的递归过程,即不添加任何的装饰器来实现。
def func(n):
'''
递归样例函数、未添加lru_cache装饰器
:param n:
:return:
'''
if n <= 1:
return n
return func(n - 1) + func(n - 2)
接下来,再使用 lru_cache 装饰器的方式实现一遍,首先,导入需要装饰器模块。
from functools import lru_cache
过程比较简单,这样准备工作就完成。然后,在代码块中直接引用即可。
@lru_cache
def func(n):
'''
递归样例函数、添加lru_cache装饰器
:param n:
:return:
'''
if n <= 1:
return n
return func(n - 1) + func(n - 2)
如上述代码所示,只需要在函数定义的部分加入装饰器的修饰大功告成了。
最后,只需要写一个main函数分别调用这两个函数就会出现显而易见的效果。
import time
'''
测试消耗时间
'''
if __name__ == '__main__':
start_time = time.time()
result = func(10)
end_time = time.time()
cost_time = end_time - start_time
print('result is ' + str(result),'cost_time is ' + str(cost_time))
通过上面@lru_cache的使用实例,可以清楚的发现cost_time is 0.0,时间上的消耗基本可以忽略不计。而在不使用此装饰器的情况下运算了半天都没有出来结果,效果是显而易见的。
@lru_cache 装饰器使用大致来讲就是将每次递归计算的数据结果作为 hash 缓存记录,当再次需要这个结果的时候就直接从缓存的数据中将结果取出避免重复计算的性能消耗。它的底层实现也牵扯到双向链表、hash表等实现处理过程,更深层次的LCU算法原理大家可以学习数据结构+算法的一些常规知识。
来源:https://mp.weixin.qq.com/s?__biz=MzA3ODk1Mzg0Mg==&mid=2649851199&idx=1&sn=1689509e5985ed60f6377df1a5c56067&chksm=87bfc922b0c8403428f381f618538f50d5df8c81afd3288603282b362516d34be2ba11b9ebcc&token=632522129&lang=zh_CN#rd
最新更新
nodejs爬虫
Python正则表达式完全指南
爬取豆瓣Top250图书数据
shp 地图文件批量添加字段
爬虫小试牛刀(爬取学校通知公告)
【python基础】函数-初识函数
【python基础】函数-返回值
HTTP请求:requests模块基础使用必知必会
Python初学者友好丨详解参数传递类型
如何有效管理爬虫流量?
2个场景实例讲解GaussDB(DWS)基表统计信息估
常用的 SQL Server 关键字及其含义
动手分析SQL Server中的事务中使用的锁
openGauss内核分析:SQL by pass & 经典执行
一招教你如何高效批量导入与更新数据
天天写SQL,这些神奇的特性你知道吗?
openGauss内核分析:执行计划生成
[IM002]Navicat ODBC驱动器管理器 未发现数据
初入Sql Server 之 存储过程的简单使用
SQL Server -- 解决存储过程传入参数作为s
关于JS定时器的整理
JS中使用Promise.all控制所有的异步请求都完
js中字符串的方法
import-local执行流程与node模块路径解析流程
检测数据类型的四种方法
js中数组的方法,32种方法
前端操作方法
数据类型
window.localStorage.setItem 和 localStorage.setIte
如何完美解决前端数字计算精度丢失与数