Python的for循环基于迭代协议运行:先调用iter()获取迭代器,再反复调用__next__()取值,直至StopIteration异常终止;break退出循环且跳过else,continue仅跳过当前轮循环体,else在未break时执行。

Python的循环不是简单地“重复执行代码”,而是基于迭代协议(Iteration Protocol)运行的。理解这个底层机制,才能真正掌握for循环、break、continue、else子句等行为背后的逻辑。
for循环本质是迭代器驱动
每次写for item in iterable:,Python实际做了三件事:先调用iter(iterable)获取一个迭代器对象;再反复调用该迭代器的__next__()方法取值;直到抛出StopIteration异常,循环自然结束。
- 可迭代对象(如list、str、dict、range)必须实现__iter__()方法,返回迭代器
- 迭代器对象必须实现__next__()和__iter__()(通常返回自身)
- 手动模拟for循环:it = iter([1,2,3]); print(next(it)); print(next(it)); ……会触发StopIteration
break和continue影响的是当前迭代流程
它们不改变迭代器状态,只控制循环体的执行跳转:
- break:立即退出整个for循环,后续迭代不再进行,也不触发else子句
- continue:跳过本轮循环体剩余语句,直接进入下一次__next__()调用
- 注意:对迭代器本身无副作用——比如用continue跳过某次,下一次next()仍返回原序列的下一个元素
for...else中的else不是“否则”,而是“未被break”
这个else子句在循环**正常完成**(即所有元素遍历完毕、自然因StopIteration结束)时才执行;只要中途遇到break,else就跳过。
立即学习“Python免费学习笔记(深入)”;
- 常见用途:搜索场景中确认“没找到”——例如遍历列表找目标值,没break说明遍历完了都没匹配
- 它和while...else逻辑一致,本质是“循环未被中断”的标记,不是if-else的分支延伸
- 不会因为continue或异常而触发,只响应break或正常结束
手动控制迭代进度:用next()配合异常处理
想跳过若干元素、条件提前终止、或分批次读取?可以绕过for语法,直接操作迭代器:
- 用next(it, default)避免StopIteration异常(default为耗尽时返回值)
- 调用多次next()可实现“快进”,例如跳过前3个元素:[next(it) for _ in range(3)]
- 结合try/except捕获StopIteration,能写出更灵活的数据流处理逻辑(如解析协议帧、流式读文件)










