博客
关于我
可迭代对象、迭代器、生成器
阅读量: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:基础——3N范式的表结构设计
查看>>
MYSQL:基础——触发器
查看>>
Mysql:连接报错“closing inbound before receiving peer‘s close_notify”
查看>>
mysqlbinlog报错unknown variable ‘default-character-set=utf8mb4‘
查看>>
mysqldump 参数--lock-tables浅析
查看>>
mysqldump 导出中文乱码
查看>>
mysqldump 导出数据库中每张表的前n条
查看>>
mysqldump: Got error: 1044: Access denied for user ‘xx’@’xx’ to database ‘xx’ when using LOCK TABLES
查看>>
Mysqldump参数大全(参数来源于mysql5.5.19源码)
查看>>
mysqldump备份时忽略某些表
查看>>
mysqldump实现数据备份及灾难恢复
查看>>
mysqldump数据库备份无法进行操作只能查询 --single-transaction
查看>>
mysqldump的一些用法
查看>>
mysqli
查看>>
MySQLIntegrityConstraintViolationException异常处理
查看>>
mysqlreport分析工具详解
查看>>
MySQLSyntaxErrorException: Unknown error 1146和SQLSyntaxErrorException: Unknown error 1146
查看>>
Mysql_Postgresql中_geometry数据操作_st_astext_GeomFromEWKT函数_在java中转换geometry的16进制数据---PostgreSQL工作笔记007
查看>>
mysql_real_connect 参数注意
查看>>
mysql_secure_installation初始化数据库报Access denied
查看>>