学会迭代器设计模式,帮你大幅提升python性能


Posted in Python onJanuary 03, 2021

大家好,我们的git专题已经更新结束了,所以开始继续给大家写一点设计模式的内容。

今天给大家介绍的设计模式非常简单,叫做iterator,也就是迭代器模式。迭代器是Python语言当中一个非常重要的内容,借助迭代器我们可以很方便地实现很多复杂的功能。在深度学习当中,数据的获取往往也是通过迭代器实现的。因此这部分的内容非常重要,推荐大家一定要掌握。

简单案例

在开始介绍设计模式之前,我们先来看一个简单的需求。假设现在我们需要根据传入的变量获取每周的前几天,比如说我们传入3返回的就是[Mon, Tue, Wed],我们传入5返回[Mon, Tue, Wed, Thu, Fri]。这个需求大家应该都能理解,非常非常简单。

如果用一个函数来实现的话,就是这样:

def return_days(n):
    week = ['Mon', 'Tue', 'Wed', 'Thu', 'Fri', 'Sat', 'Sun']
    return week[:n]

你看三行代码就实现了,在这个问题场景当中这样写当然是没有问题。但假如我们把题目稍微变一变,这里的week不是一个固定的数据,而是从上游或者是某个文件当中读取的。这里的n也是一个很大的数,我们把这个函数改写成这样:

def get_data(n):
    data = []
    for i in range(n):
        data.append(get_from_upstream())
    return data

我们假设get_from_upstream这个函数当中实现了获取数据的具体逻辑,那么上面这一段函数有一个什么问题?

有些同学会说这没有问题啊,因为像是其他语言实现数据获取的时候也都是这么干的。的确,像是Java等语言可能都是这么干的。但是其他语言这么干没错,不代表Python这么干也没错。因为我们没有把Python的能力发挥到最大。

这里有两个问题,第一个问题是延迟,因为前面说了,n是一个很大的数。我们从上游获取数据,无论是通过网络还是文件读取,本质上都是IO操作,IO操作的延迟是非常大的。那么我们把这n条数据全部搜集完可能需要很长的时间,导致下游的漫长等待。第二个问题就是内存,因为我们存储了这n条数据一起返回的,如果n很大,对于内存的开销压力也很大,如果机器内存不够很有可能导致崩溃。

那怎么解决呢?

其实解决的方法很简单,如果对迭代器熟悉的话,会发现迭代器针对的恰恰是这两个问题。我们把上面的逻辑改写成迭代器实现即可,这也就是iterator模式。

iterator模式

iterator模式严格说起来其实只是迭代器的一种应用,它非常巧妙地将迭代器与匿名函数结合在一起,里面也没有太多的门道可以说,我们把刚才的代码改写一下,细节都在代码当中。

def get_data(n):
    for i in range(n):
  yield get_from_upstream()


data_10 = lambda: get_data(10)
data_100 = lambda: get_data(100)

# use
for d in data_10:
    print(d)

很简单吧,但可能你要问了,我们既然写出了get_data这个迭代器,那么我们使用的时候直接for d in get_data(10)这样用不就好了,为什么中间要用匿名函数包一层呢?

道理也很简单,如果这个数据是我们自己使用,当然是没必要中间包一层的。但如果我们是传给下游使用的话,对于下游来说它肯定是不希望考虑上游太多的细节的,越简单越好。所以我们直接丢一个包装好的迭代器过去,下游直接call即可。否则的话,下游还需要感知get_data这个函数传入的参数,显然是不够合理的。

以上就是学会迭代器设计模式,帮你大幅提升python性能的详细内容,更多关于python 迭代器设计模式的资料请关注三水点靠木其它相关文章!

Python 相关文章推荐
Python字符串替换实例分析
May 11 Python
在Django的模型中执行原始SQL查询的方法
Jul 21 Python
在Python程序和Flask框架中使用SQLAlchemy的教程
Jun 06 Python
python3实现抓取网页资源的 N 种方法
May 02 Python
Flask框架Jinjia模板常用语法总结
Jul 19 Python
使用Selenium破解新浪微博的四宫格验证码
Oct 19 Python
Python同步遍历多个列表的示例
Feb 19 Python
python使用flask与js进行前后台交互的例子
Jul 19 Python
django 模型中的计算字段实例
May 19 Python
Python变量格式化输出实现原理解析
Aug 06 Python
Pycharm 如何一键加引号的方法步骤
Feb 05 Python
python小程序之飘落的银杏
Apr 17 Python
Python编写万花尺图案实例
Jan 03 #Python
Python 实现一个简单的web服务器
Jan 03 #Python
关于Python错误重试方法总结
Jan 03 #Python
详解python中的异常和文件读写
Jan 03 #Python
python绘制雷达图实例讲解
Jan 03 #Python
python 使用xlsxwriter循环向excel中插入数据和图片的操作
Jan 01 #Python
python安装mysql的依赖包mysql-python操作
Jan 01 #Python
You might like
php json转换成数组形式代码分享
2014/11/10 PHP
Yii获取当前url和域名的方法
2015/06/08 PHP
CI框架简单邮件发送类实例
2016/05/18 PHP
JS+CSS实现带关闭按钮DIV弹出窗口的方法
2015/02/27 Javascript
jQuery中的Deferred和promise 的区别
2016/04/03 Javascript
使用JavaScript判断手机浏览器是横屏还是竖屏问题
2016/08/02 Javascript
webpack+vue.js实现组件化详解
2016/10/12 Javascript
express文件上传中间件Multer详解
2016/10/24 Javascript
layui弹出层效果实现代码
2017/05/19 Javascript
深究AngularJS——ng-checked(回写:带真实案例代码)
2017/06/13 Javascript
使用jQuery实现简单的tab框实例
2017/08/22 jQuery
element上传组件循环引用及简单时间倒计时的实现
2018/10/01 Javascript
JS实现textarea通过换行或者回车把多行数字分割成数组并且去掉数组中空的值
2018/10/29 Javascript
详解webpack 最简打包结果分析
2019/02/20 Javascript
详解js中let与var声明变量的区别
2020/04/05 Javascript
d3.js实现图形拖拽
2019/12/19 Javascript
解决vue scoped html样式无效的问题
2020/10/24 Javascript
python 解析XML python模块xml.dom解析xml实例代码
2014/02/07 Python
Python如何爬取实时变化的WebSocket数据的方法
2019/03/09 Python
python3字符串操作总结
2019/07/24 Python
Python使用re模块验证危险字符
2020/05/21 Python
python实现PolynomialFeatures多项式的方法
2021/01/06 Python
Bibloo奥地利:购买女装、男装、童装、鞋和配件
2018/10/18 全球购物
简述你对Statement,PreparedStatement,CallableStatement的理解
2013/03/25 面试题
易程科技软件测试笔试
2013/03/24 面试题
教师申诉制度
2014/01/29 职场文书
酒店员工检讨书
2014/02/18 职场文书
预防传染病方案
2014/06/14 职场文书
住房租房协议书
2014/08/20 职场文书
饭店服务员岗位职责
2015/02/09 职场文书
自我评价优缺点范文
2015/03/11 职场文书
奔腾年代观后感
2015/06/09 职场文书
如何写通讯稿
2015/07/22 职场文书
CSS的class与id常用的命名规则
2021/05/18 HTML / CSS
HTML基础详解(下)
2021/10/16 HTML / CSS
多台电脑共享文件怎么设置?多台电脑共享文件操作教程
2022/04/08 数码科技