Python try except finally資源回收的實現
Python 異常處理機制還提供了一個 finally 語句,通常用來為 try 塊中的程序做掃尾清理工作。
注意,和 else 語句不同,finally 只要求和 try 搭配使用,而至于該結構中是否包含 except 以及 else,對于 finally 不是必須的(else 必須和 try except 搭配使用)。
在整個異常處理機制中,finally 語句的功能是:無論 try 塊是否發生異常,最終都要進入 finally 語句,并執行其中的代碼塊。
基于 finally 語句的這種特性,在某些情況下,當 try 塊中的程序打開了一些物理資源(文件、數據庫連接等)時,由于這些資源必須手動回收,而回收工作通常就放在 finally 塊中。
Python 垃圾回收機制,只能幫我們回收變量、類對象占用的內存,而無法自動完成類似關閉文件、數據庫連接等這些的工作。
讀者可能會問,回收這些物理資源,必須使用 finally 塊嗎?當然不是,但使用 finally 塊是比較好的選擇。首先,try 塊不適合做資源回收工作,因為一旦 try 塊中的某行代碼發生異常,則其后續的代碼將不會得到執行;其次 except 和 else 也不適合,它們都可能不會得到執行。而 finally 塊中的代碼,無論 try 塊是否發生異常,該塊中的代碼都會被執行。
舉個例子:
try: a = int(input('請輸入 a 的值:')) print(20/a)except: print('發生異常!')else: print('執行 else 塊中的代碼') finally : print('執行 finally 塊中的代碼')
運行此程序:請輸入 a 的值:45.0執行 else 塊中的代碼執行 finally 塊中的代碼
可以看到,當 try 塊中代碼為發生異常時,except 塊不會執行,else 塊和 finally 塊中的代碼會被執行。
再次運行程序:請輸入 a 的值:a發生異常!執行 finally 塊中的代碼
可以看到,當 try 塊中代碼發生異常時,except 塊得到執行,而 else 塊中的代碼將不執行,finally 塊中的代碼仍然會被執行。
finally 塊的強大還遠不止此,即便當 try 塊發生異常,且沒有合適和 except 處理異常時,finally 塊中的代碼也會得到執行。例如:
try: #發生異常 print(20/0)finally : print('執行 finally 塊中的代碼')
程序執行結果為:執行 finally 塊中的代碼Traceback (most recent call last): File 'D:python3.61.py', line 3, in <module> print(20/0)ZeroDivisionError: division by zero
可以看到,當 try 塊中代碼發生異常,導致程序崩潰時,在崩潰前 Python 解釋器也會執行 finally 塊中的代碼。
到此這篇關于Python try except finally資源回收的實現的文章就介紹到這了,更多相關Python try except finally 內容請搜索好吧啦網以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持好吧啦網!
相關文章:
