博客
关于我
可迭代对象、迭代器、生成器
阅读量: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 DBA 数据库优化策略
查看>>
multi_index_container
查看>>
mutiplemap 总结
查看>>
MySQL Error Handling in Stored Procedures---转载
查看>>
MVC 区域功能
查看>>
MySQL FEDERATED 提示
查看>>
mysql generic安装_MySQL 5.6 Generic Binary安装与配置_MySQL
查看>>
Mysql group by
查看>>
MySQL I 有福啦,窗口函数大大提高了取数的效率!
查看>>
mysql id自动增长 初始值 Mysql重置auto_increment初始值
查看>>
MySQL in 太多过慢的 3 种解决方案
查看>>
Mysql Innodb 锁机制
查看>>
MySQL InnoDB中意向锁的作用及原理探
查看>>
MySQL InnoDB事务隔离级别与锁机制深入解析
查看>>
Mysql InnoDB存储引擎 —— 数据页
查看>>
Mysql InnoDB存储引擎中的checkpoint技术
查看>>
Mysql InnoDB存储引擎中缓冲池Buffer Pool、Redo Log、Bin Log、Undo Log、Channge Buffer
查看>>
MySQL InnoDB引擎的锁机制详解
查看>>
Mysql INNODB引擎行锁的3种算法 Record Lock Next-Key Lock Grap Lock
查看>>
mysql InnoDB数据存储引擎 的B+树索引原理
查看>>