可迭代对象、迭代器、for循环本质

一. 可迭代对象

1. 迭代

迭代即更新换代 每次的更新都必须依赖于上一次的结果

迭代其实给我们提供了一种不依赖索引取值的方式

2. 可迭代对象

内置有__iter__方法的都称之为可迭代对象	
    	内置的意思是可以通过点的方式直接查看到的
     针对双下滑线开头 双下滑线结尾的方法 最为专业标准的读法为
    	双下方法名
    	
    面向对象的时候为了与隐藏变量区分开
i = 12  # 没有__iter__
f = 11.11  # 没有__iter__
s = 'jason'  # 有__iter__
l = [111,22,33,4]  # 有__iter__
d = {'username':'jason','pwd':123}  # 有__iter__
t = (11,22,33)  # 有__iter__
se = {11,22,33}  # 有__iter__
b = True  # 没有__iter__
file = open(r'a.txt','w',encoding='utf8') # 有__iter__
含有__iter__的有
    字符串 列表 字典 元组 集合 文件对象
上述通常为可迭代对象
可迭代对象调用__iter__方法会变成迭代器对象(老母猪)

3. 迭代器对象

"""
迭代器对象
    即含有__iter__方法 又含有__next__方法
如何生成迭代器对象
    让可迭代对象执行__iter__方法

文件对象本身即是可迭代对象又是迭代器对象
迭代器对象无论执行多少次__iter__方法 还是迭代器对象(本身)

迭代器给我们提供了不依赖于索引取值的方式
"""
i = 12  # 没有__iter__
f = 11.11  # 没有__iter__
s = 'jason'  # 转迭代器前没有__next__
l = [111,222,333,444]  # 转迭代器前没有__next__
d = {'username':'jason','pwd':123}  # 转迭代器前没有__next__
t = (11,22,33)  # 转迭代器前没有__next__
se = {11,22,33}  # 转迭代器前没有__next__
b = True  # 没有__iter__
file = open(r'a.txt','w',encoding='utf8')  # 有__next__

res = d.__iter__()  # 转成迭代器对象
print(res.__next__())  # 迭代器对象执行__next__方法其实就是在迭代取值(for循环)
print(res.__next__())
print(res.__next__())  # 取完元素之后再取会"报错"

4. for循环的本质

for循环内部原理
1.将关键字in后面的数据先调用_ _ iter _ _方法转为迭代器对象
2.循环执行 _ _ next _ _ 方法
3.取完之后 _ _ next _ _ 会报错 但是for循环会自动捕获该错误并处理

res = 数据.__iter__()
while True:
    检测代码是否会报错
    res.__next__()
    如果报错了则自动处理掉并结束while循环

image

posted @   zong涵  阅读(74)  评论(0编辑  收藏  举报
编辑推荐:
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
阅读排行:
· Manus爆火,是硬核还是营销?
· 终于写完轮子一部分:tcp代理 了,记录一下
· 别再用vector<bool>了!Google高级工程师:这可能是STL最大的设计失误
· 单元测试从入门到精通
· 震惊!C++程序真的从main开始吗?99%的程序员都答错了
点击右上角即可分享
微信分享提示