hello,大家好,我是 Jackpop,硕士毕业于哈尔滨工业大学,曾在华为、阿里等大厂工作,如果你对升学、就业、技术提升等有疑惑,不妨交个朋友:

我是Jackpop,我们交个朋友吧!

可以做的事情太多了!一行代码足以把程序的执行速度提升超过10000倍!


缓存是一项从底层到高层都广泛应用的技术,无论是前端还是后端,有一定开发经验的程序员对缓存应该都不陌生。缓存是指可以进行高速数据交换的存储器,它先于内存与CPU交换数据,因此速率很快。

在Python开发过程中,有一些函数的结果可能会被反复调用,如果这个函数耗时较少还无伤大雅。

但是,如果一个函数耗时10分钟,或者频繁的发送rest请求,那么耗时就会呈现非线性上升。

那么,对于很多开发人员抱怨的Python,是否能够通过缓存来提升它的开发效率?

答案是肯定的!

本文就来介绍如果利用缓存这项技术,实现1行代码提升Python执行速度。

LRU

不同的编程语言,会有不同 的缓存策略,例如,通过哈希映射、优先级队列等实现缓存。因此,不同的编程语言,在缓存的解决方案方面具有很大差异,可能需要几分钟,也可能需要几小时。

但是,在Python中,标准工具包functools实现了一种名为LRU(Least Recently Used)的缓存策略,可以通过传入参数,来设定缓存最近多少次的计算结果,如果传入参数为None,那么会进行无限缓存。

现在,为了让大家更加容易理解,先来举一个例子,

import time as tt
​
def func():num = 0for i in range(10):num += i
​return num
​
​
def main():return func() + func() + func() + func() + func() + func() + func()
​
​
t1 = tt.time()
main()
print("Time taken: {}".format(tt.time() - t1))
# 9.05990e-6

在这个示例中,反复的调用了func函数,总共耗时为0.009秒。

下面,通过functools工具包下LRU缓存再跑一下,

import time as tt
import functools
​
@functools.lru_cache(maxsize=5)
def func():num = 0for i in range(10):num += i
​return num
​
​
def main():return func() + func() + func() + func() + func() + func() + func()
​
​
t1 = tt.time()
main()
print("Time taken: {}".format(tt.time() - t1))
# 4.768371e-06

通过数据对比,发现运行时间减少了将近50%。

在调用lru_cache时,需要配置一个maxsize的参数,它代表着缓存最近几次的函数计算结果,如果参数为none则不进行缓存。

通过前面的对比,会发现利用缓存机制时间差别会很大,这是由于,重复调用函数,需要反复执行计算过程,而利用缓存,我们只需要进行快速读写,不再需要重复执行计算过程,这样会节省大部分时间。

但是,由于前面计算过程较为简单,只涉及简单的加法运算,在耗时方面给人直观的感受并不是很强烈。

那下面在以另外斐波那契数列的例子进行对比一下。

应该很多同学对斐波那契数列都不陌生,一个很典型的递归问题,在教材上也频繁的出现。

由于它递归计算的过程中,还会用到之前计算的结果,因此会涉及较多的重复计算,下面先看一下正常计算的耗时情况。

import time as tt
​
def fib(n):if n <= 1:return nreturn fib(n-1) + fib(n-2)
​
t1 = tt.time()
fib(30)
print("Time taken: {}".format(tt.time() - t1))
# 0.2073

加一行@functools.lru_cache(maxsize=5) 之后,看看效果:

import time as tt
import functools
​
@functools.lru_cache(maxsize=5)
def fib(n):if n <= 1:return nreturn fib(n-1) + fib(n-2)
​
t1 = tt.time()
fib(30)
print("Time taken: {}".format(tt.time() - t1))
# 1.811981e-05

0.2073秒对比2.0981e-5秒之间差了4个量级,快了10000+倍!这样给人的直观感受应该就非常强烈了。

在涉及一些简单运算的过程中,即便是重复计算也无伤大雅。但是,如果涉及大量数据计算或者网络请求这类耗时的计算,利用缓存机制,只需要1行代码就可以节省可观的时间。既比重复计算节省时间,也要比多余定义变量简单。


干货

最近,为了方便大家,我花费了半个月的时间把这几年来收集的各种技术干货整理到一起,其中内容包括但不限于Python、机器学习、深度学习、计算机视觉、推荐系统、Linux、工程化、Java,内容多达5T+,我把各个资源下载链接整理到一个文档内,目录如下:

所有干货送给大家,希望能够点赞支持一下!

https://pan.baidu.com/s/1eks7CUyjbWQ3A7O9cmYljA (提取码:0000)

一行代码可以做什么?相关推荐

  1. 【Python】Python一行代码能做什么,30个实用案例代码详解

    Python语法简洁,能够用一行代码实现很多有趣的功能,这次来整理30个常见的Python一行代码集合. 1.转置矩阵 old_list = [[1, 2, 3], [3, 4, 6], [5, 6, ...

  2. 我是Python小玩家,一行代码能做哪些炫酷的事情 (三十一)

    文章目录 python之禅 一行代码启动一个Web服务 一行代码实现变量值互换 一行代码打印迷宫 解决FizzBuzz问题 一行代码输出特定字符"Love"拼成的心形 一行代码输出 ...

  3. 一行代码能做什么? 看到最后一个我终于忍不住...

    技术能力的提升需要不断的学习和实践,面对一行行枯燥的代码,做出有趣的事情,更能增加学习的兴趣和乐趣. 那一行python代码能做出什么有趣的东西?C/C++有什么趣味设计?有哪些趣味的Scratch小 ...

  4. Python一行代码能做什么,30个实用案例代码详解

    Python语法简洁,能够用一行代码实现很多有趣的功能,这次来整理30个常见的Python一行代码集合. 1.转置矩阵 old_list = [[1, 2, 3], [3, 4, 6], [5, 6, ...

  5. python可以实现什么炫酷图形吗_我是Python小玩家,一行代码能做哪些炫酷的事情?...

    python之禅 image 一行代码启动一个Web服务 python -m SimpleHTTPServer 8080 python3 -m http.server 8080 一行代码实现变量值互换 ...

  6. 《Python One-Liners》电子书分享,一行代码可以做些什么?

    有道是"人生苦短,我用Python". Python 拥有简洁易用的语法,经验丰富的程序员可以通过简短的代码,实现非常丰富的功能.这也是脚本语言的特性之一. 近日,偶然看到 202 ...

  7. 一行SQL代码能做什么?

    最近在知乎上看到一个问题:一行代码可以做什么?答题者数万计,都是一些非常"高端"的操作,就在想一行SQL代码能做什么呢? SQL一行代码其实有很多很多,一些常见的比如: SELEC ...

  8. python可以干嘛知乎-一行Python代码能做什么?

    原标题:一行Python代码能做什么? 作者:笑虎 来源:知乎 首先你要了解一下Python之禅,一行代码输出"The Zen of Python": python -c &quo ...

  9. python代码做图_超好看的弦图,Python一行代码就能做

    原标题:超好看的弦图,Python一行代码就能做 说起可视化图表,那么弦图( C hord Diagram)一定是颜值担当了,比如我们通过使用百度迁徙数据来可视化展示武汉及其周边城市的迁徙数据

最新文章

  1. unity3d 调用Start 注意
  2. 启动子级时出错_【本音知识】弹钢琴时如何背谱?
  3. 锚杆拉拔试验弹性模量计算_土钉、锚杆拉拔试验检测方案 - 图文 -
  4. 新康众闫顺成:数据中台建设中的得与失
  5. Python会干掉Java, 一统天下?
  6. 剖析IE浏览器子系统的性能权重
  7. JAVA连接数据库ij_Derby 客户端 ij使用
  8. java 线程参数 用final,JAVA 关于final修饰变量参数
  9. 新华三的背景_智能联接,新华三在重新勾勒拓扑图
  10. jQuery框架学习第九天:jQuery工具函数介绍与使用
  11. 刀片 显卡 排行_沈阳家政连锁公司前十名排行榜
  12. 传统数据库在分布式领域的探索
  13. C语言的中常用的函数
  14. 在计算机网络中 将网络的层次结构图,计算机网络基础试卷8
  15. 仿迅雷播放器教程 -- 提取exe资源
  16. 计算机视觉——Harris角点检测(课堂实验)
  17. itunes显示无法更新服务器失败怎么办啊,iTunes更新时出错怎么办?iTunes更新时出错的解决方法...
  18. Linux安装杀毒软件clamav
  19. 建筑力学与结构【3】
  20. 2022上半年系统分析师必考知识点

热门文章

  1. DTU是什么?浅解DTU
  2. 想骂人!开发语言不能统一成一个么?
  3. 基于51单片机的温度报警系统(程序分装)
  4. ただの南條きみつだ。
  5. 实现Python爬虫的思路、原理
  6. 斗地主中自主出牌的游戏逻辑
  7. JAVA访问修饰符限制性最高的_问:JAVA中,访问修饰符限制性最高的是protected ( )...
  8. 公链应用争夺战:未来区块链生态真的“根特多,叶子少”?
  9. Matplotlib绘制圆环图
  10. 牛客网-2018 美团 CodeM 编程大赛-初赛 A 轮