迭代器
迭代器从字面的意思来讲就是迭代取值的工具。迭代是一个重复的过程,并且每一次的重复都会基于上一次的结果而来。
像之前我们所了解的字符串,列表,元组这些有索引的可以依靠索引来取值,而像字典,集合,文件等类型是没有索引的,就需要用到一种迭代方式来取出其内部的元素,这种方式就叫做迭代器
对于迭代器并不是所有的的对象都是可以迭代的,在python当中,只要内置有__iter__方法的对象,都是可迭代的对象
'hello'.__iter__
(1,2,3).__iter__
[1,2,3].__iter__
{'a':1}.__iter__
{'a','b'}.__iter__
open('a.txt').__iter__
# 数据类型当中除了数字之外,都是可迭代的对象
当我们对可迭代对象使用“__iter__”操作得到的结果就是迭代器对象,在迭代器的内置当中既有“__iter__”又有“__next__”,也就是说迭代器对象也是可迭代对象,像文件类型本身就是迭代器对象
open('a.txt').__iter__()
open('a.txt').__next__()
# 可迭代对象一定是迭代器对象,迭代器对象不一定是可迭代对象
l='hello' iter_l=l.__iter__() while True: try: # 监控迭代过程 print(iter_l.__next__()) except StopIteration: break # 迭代器的迭代过程每一次都会基于上一次的结果,当迭代到最后一步的时候字符串内所有的元素都已经迭代完之后,再次执行,系统就会抛出异常StopIteration,
这就需要用到“try...except”来监控整个迭代过程,当所有元素迭代完成,自动停止运行
迭代器对象的使用
dic={'a':1,'b':2,'c':3}
iter_dic=dic.__iter__() # 得到迭代器对象,迭代器对象既有__iter__又有__next__,但是:迭代器.__iter__()得到的仍然是迭代器本身
iter_dic.__iter__() is iter_dic #True
print(iter_dic.__next__()) #等同于next(iter_dic)
print(iter_dic.__next__()) #等同于next(iter_dic)
print(iter_dic.__next__()) #等同于next(iter_dic)
# print(iter_dic.__next__()) #抛出异常StopIteration,或者说结束标志
for循环
#基于for循环,我们可以完全不再依赖索引去取值了
dic={'a':1,'b':2,'c':3}
for k in dic:
print(dic[k])
#for循环的工作原理
#1:执行in后对象的dic.__iter__()方法,得到一个迭代器对象iter_dic
#2: 执行next(iter_dic),将得到的值赋值给k,然后执行循环体代码
#3: 重复过程2,直到捕捉到异常StopIteration,结束循环
迭代器的优缺点
优点:
1、提供了一种不依赖索引的取值方式
2、更加节省内存
缺点:
取值比较麻烦,只可以一个一个取,只可以往后取,并且都是一次性取值,没有办法使用len来获取长度(只有在next结束之后才会知道到底取了几个值)
生成器
函数内含有yield关键字,那么函数名()得到的结果就生成器,并且不会执行函数内部的代码
生成器就是迭代器
# dic={'x':1,'y':2,'z':3}
# iter_dic=dic.__iter__()
# def index():
# print('====>1')
# yield 7
# print('====>2')
# yield 8
# print('====>3')
# yield 9
# obj=index()
# res=obj.__next__()
# print(res)
# res=obj.__next__()
# print(res)
# res=obj.__next__()
# print(res)
总结yield
1、为我们提供了一种自定义迭代器的方式,可以在函数内用yield关键字,调用函数拿到的结果就是一个生成器,生成器就是迭代器
2、yield可以和return一样用于返回值,区别是return只可以返回一次值,而yield可以返回多次,yield可以保存函数执行的状态,通俗一点来说就是将函数暂停
面向过程编程
面向过程编程不是一种单纯的函数编程,而是一种编程思想,这种编程思想不依赖与具体的语法还有语言,所以我们可以不依赖于函数,而依赖面向过程的思想编程
#2、定义
面向过程的核心是过程二字,过程指的是解决问题的步骤,即先干什么再干什么
基于面向过程设计程序就好比在设计一条流水线,是一种机械式的思维方式
#3、优点:复杂的问题流程化,进而简单化
#4、缺点:可扩展性差,修改流水线的任意一个阶段,都会牵一发而动全身
#5、应用:扩展性要求不高的场景,典型案例如linux内核,git,httpd