打开APP
userphoto
未登录

开通VIP,畅享免费电子书等14项超值服

开通VIP
计算速度太慢?试试 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算法原理大家可以学习数据结构+算法的一些常规知识。

本站仅提供存储服务,所有内容均由用户发布,如发现有害或侵权内容,请点击举报
打开APP,阅读全文并永久保存 查看更多类似文章
猜你喜欢
类似文章
【热】打开小程序,算一算2024你的财运
【每日一问】Python中的装饰器是什么?
从零开始学Python:21课-函数的高级应用
】LRU 淘汰算法
Python算法:动态规划
python基础|开发一个任务超时退出的装饰器
Python 中惊人的 Functools 特性
更多类似文章 >>
生活服务
热点新闻
分享 收藏 导长图 关注 下载文章
绑定账号成功
后续可登录账号畅享VIP特权!
如果VIP功能使用有故障,
可点击这里联系客服!

联系客服