博客
关于我
python~迭代器,生成器(2)
阅读量:538 次
发布时间:2019-03-09

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

生成器与迭代器的区别

在程序编程中,生成器和迭代器是常见的概念,但二者的区别容易引起混淆。一个重要的原则是:生成器一定是迭代器,但迭代器不一定是生成器。

迭代器的定义

迭代器是能够通过next()函数获取下一个值的对象。利用isinstance()函数可以判断一个对象是否为迭代器。例如:

from collections import Iteratorisinstance((x for x in range(10)), Iterator) → Trueisinstance([], Iterator) → Falseisinstance({}, Iterator) → Falseisinstance('abc', Iterator) → Falseisinstance(100, Iterator) → False

iter()函数的作用

虽然列表(如list)、字典和字符串等数据类型属于Iterable,但它们并不是迭代器。要将它们转换为迭代器,可以使用iter()函数:

isinstance(iter([]), Iterator) → Trueisinstance(iter('abc'), Iterator) → True

总结

:valuearea>

任何可作用于for循环的对象都是Iterable;

任何可作用于next()函数的对象都是Iterator。

虽然集合数据类型如listdictstr是Iterable,但它们本身不是Iterator。通过iter()函数可以将它们转换为Iterator对象。

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

你可能感兴趣的文章
MySQL DELETE 表别名问题
查看>>
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事务隔离级别与锁机制深入解析
查看>>
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+树索引原理
查看>>