生成器函数可通过 throw() 或 close() 提前终止并触发清理逻辑,关键在于用 try...finally 保证 finally 中的资源释放代码必然执行,或响应 GeneratorExit 异常完成清理。
生成器函数可以通过外部调用 throw() 或 close() 方法提前终止,从而触发清理逻辑。关键在于利用 try...finally 块或 generator.close() 触发的 GeneratorExit 异常来执行资源释放。
在生成器内部用 try...finally 包裹资源操作,无论是否被外部中断,finally 块都会运行:
try 前或 try 中finally 块中gen.close() 或 gen.throw(GeneratorExit),finally 仍会执行调用生成器对象的

close() 方法会向其抛出 GeneratorExit 异常,此时生成器必须退出(不能捕获该异常并继续 yield):
GeneratorExit 是一个特殊异常,不可被常规 except Exception: 捕获,需显式写 except GeneratorExit:
finally 外捕获了 GeneratorExit,必须在处理完后重新抛出或直接 return,否则会触发 RuntimeError
GeneratorExit,而依赖 finally 完成清理外部可调用 gen.throw(exc_type, exc_value, traceback) 向生成器注入任意异常,适合主动中断并走特定错误处理分支:
except MyCustomError: 捕获并执行对应清理逻辑StopIteration 或 RuntimeError
try...except...finally 可实现“按需中断 + 统一清理”以下是一个安全释放文件句柄的生成器写法:
def read_lines_safely(filename):
f = None
try:
f = open(filename)
for line in f:
yield line.strip()
finally:
if f is not None and not f.closed:
f.close() # 无论正常结束、close() 还是 throw() 都会执行
外部可随时调用 gen.close() 终止迭代并确保文件关闭。