博客
关于我
可迭代对象、迭代器、生成器
阅读量:718 次
发布时间:2019-03-21

本文共 1402 字,大约阅读时间需要 4 分钟。

可迭代对象、迭代器、生成器是Python中常用的概念,但它们之间的区别和特点可能让很多开发者感到困惑。本文将从这些概念的实现原理入手,详细阐述它们的关系以及如何在实际编程中使用。

1. type和isinstance的区别

在Python中,type()函数返回的是对象的类对象,而isinstance()函数用于判断对象是否是某个类或其父类的实例。通过比较这两个函数的作用可以得出明确的结论。例如,一个对象o为创建的列表实例,那么:

  • type(o) == list
  • isinstance(o, list)返回True

这两种函数在类型判断中有明显的区别。

2. 三者所属类型

根据Python的官方文档,collections库中的Iterable接口 defines iterable object, Iterator接口定义了迭代器,Generator接口定义了生成器。这些接口分别用于不同的功能,但它们之间存在一定的关联关系。


可迭代对象

要实现一个可迭代对象,需要在类中定义__iter__方法。这个方法返回一个迭代器对象。需要注意的是,返回的值必须是一个支持__next__方法的迭代器对象,否则无法实现迭代功能。

有趣的是,一个能被for循环遍历的对象并不一定是可迭代对象。你可能会疑惑,这到底是什么意思呢?让我们来看个具体示例。

在示例代码中,某实例对象可以被for循环遍历,但它却不是一个可迭代对象。这意味着,__iter__方法的返回值虽然支持迭代,但它并不符合Iterable接口的要求。这个细节在编写高效代码时非常重要。


for循环机制

Python中的for循环工作机制非常清晰。它会首先查找对象的__iter__方法。如果找不到,就会查找__getitem__方法。如果两者都不行,那么这个对象就不支持迭代。

如果使用__iter__方法,for循环会获取返回的迭代器,并不断调用__next__方法,直到抛出StopIteration异常。

如果使用__getitem__方法,for循环会按照索引值依次调用__getitem__,从0开始,直到索引超出范围或抛出异常。


迭代器

迭代器是指那些同时实现了__iter____next__方法的对象。简单来说,如果一个对象既能创建迭代器,又能提供下一个元素的获取方式,那么它就是一个迭代器。

生成器就是迭代器中的一种特殊类型,它在生成迭代器的过程中会自动暂停,并在必要时继续。这与传统的迭代器有明显区别。


生成器

生成器是通过在函数中使用yield关键字创建的。生成器在执行到yield时会暂停,并且回到顶层for循环的处理。当继续调用next()时,生成器会继续执行任务,直到再次遇到yield

生成器的一个显著特点是,它可以表现得像一个无限迭代器,无论生成的数据量有多大。


总结

  • 实现了__iter__方法的类创建的实例对象都是可迭代对象。
  • 实现了__iter____next__方法的实例对象才是迭代器。
  • 通过在函数中使用yield关键字创建的函数返回的实例是生成器。

要注意的是,虽然生成器是迭代器,但不是所有迭代器都是生成器。两者之间没有包含关系,而是各有特点。

如果你在编写Python代码时希望代码既高效又简洁,理解这些概念的区别无疑是非常重要的。希望这一段内容能帮助你更好地理解Python中的迭代机制!

转载地址:http://xderz.baihongyu.com/

你可能感兴趣的文章
mysql case when 乱码_Mysql CASE WHEN 用法
查看>>
Multicast1
查看>>
MySQL Cluster 7.0.36 发布
查看>>
Multimodal Unsupervised Image-to-Image Translation多通道无监督图像翻译
查看>>
MySQL Cluster与MGR集群实战
查看>>
multipart/form-data与application/octet-stream的区别、application/x-www-form-urlencoded
查看>>
mysql cmake 报错,MySQL云服务器应用及cmake报错解决办法
查看>>
Multiple websites on single instance of IIS
查看>>
mysql CONCAT()函数拼接有NULL
查看>>
multiprocessing.Manager 嵌套共享对象不适用于队列
查看>>
multiprocessing.pool.map 和带有两个参数的函数
查看>>
MYSQL CONCAT函数
查看>>
multiprocessing.Pool:map_async 和 imap 有什么区别?
查看>>
MySQL Connector/Net 句柄泄露
查看>>
multiprocessor(中)
查看>>
mysql CPU使用率过高的一次处理经历
查看>>
Multisim中555定时器使用技巧
查看>>
MySQL CRUD 数据表基础操作实战
查看>>
multisim变压器反馈式_穿过隔离栅供电:认识隔离式直流/ 直流偏置电源
查看>>
mysql csv import meets charset
查看>>