迭代器和生成器

一直以来迭代器和生成器都是很神秘的,听起来就感觉很难,今天正好看到,打算写一下,记录一下。

1.迭代器

迭代器是访问集合元素的一种方式,迭代器对象从集合的第一个元素开始访问,直到所有的元素被访问结束,但是整个过程只能前进不能后退,一直到全部的元素被访问结束。另外,迭代器的特点是不需要所有的元素全部准备好才开始,只要到这个元素之前获取这个元素就可以,这样可以遍历一些大的数据和集合。
特点:(借鉴了其他人的内容):
1.访问者不需要关心迭代器内部的结构,仅需要通过next() 方法不断去取下一个内容
2.不能随机访问集合中的某个值,只能从头到尾依次访问
3.访问到一半的时候不能往回退
4.便于循环比较大的数据集合,节省内存
贴上我的代码段:
在这里插入图片描述

2.生成器

一个函数调用时返回一个迭代器,那么这个函数就叫做生成器(generator),如果函数中包含yield语法,那这个函数就会变成生成器。
在这里插入图片描述

func() 称之为生成器,执行这个函数的时候会生成迭代器。

实例:
在这里插入图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值