finally子句在try块开始执行后无论是否发生异常都会运行,即使遇到return、break等也会在跳转前执行,适合用于释放资源等必须操作。
在 Python 中,finally 子句主要用于确保某些代码无论是否发生异常都
会被执行。理解它的执行时机对编写健壮的程序很重要。
finally 的基本执行规则
finally 子句属于 try-except 语句的一部分,其执行时机如下:
- 只要 try 块开始执行,无论是否抛出异常,finally 中的代码最终都会运行。
- 即使 try 或 except 中包含 return、break、continue 等控制流语句,finally 依然会在函数返回或跳出前执行。
- 如果异常未被 except 捕获,finally 仍会执行,然后异常继续向上抛出。
常见执行场景示例
下面几种情况可以更清楚地说明 finally 的行为:
1. 正常执行流程
try 块中没有异常时,finally 在 try 结束后立即执行。
try:
print("try 执行")
finally:
print("finally 执行")
# 输出:
# try 执行
# finally 执行
2. 发生异常但被捕获
except 处理完异常后,finally 依然会执行。
try:
print(1 / 0)
except ZeroDivisionError:
print("捕获异常")
finally:
print("finally 执行")
# 输出:
# 捕获异常
# finally 执行
3. 发生未被捕获的异常
finally 执行后,异常才会被重新抛出。
try:
print("try")
raise ValueError("出错")
finally:
print("清理资源")
# 输出:
# try
# 清理资源
# 然后抛出 ValueError
4. try 中有 return
即使 try 中有 return,finally 也会在 return 之前执行。
def func():
try:
return "返回值"
finally:
print("finally 执行")
print(func())
输出:
finally 执行
返回值
特殊情况注意
虽然 finally 几乎总能执行,但以下情况例外:
- 程序在 try 块执行前就终止(如 os._exit())。
- 解释器崩溃或系统断电等极端情况。
- 在 finally 执行过程中也发生异常或调用 sys.exit()。
基本上就这些。finally 最适合用于释放资源、关闭文件、断开连接等必须执行的操作,保证程序的可靠性。掌握它的执行时机,能避免很多“以为执行了但实际上没执行”的问题。








