Python finally 子句的执行时机

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 最适合用于释放资源、关闭文件、断开连接等必须执行的操作,保证程序的可靠性。掌握它的执行时机,能避免很多“以为执行了但实际上没执行”的问题。