python - 為什么這段代碼沒有異常拋出?
問題描述
In [8]: def bar(): ...: a = 10 ...: try: ...: raise ...: except: ...: try: ...: raise ...: except: ...: raise ...: finally: ...: return aIn [9]: bar()Out[9]: 10
問題解答
回答1:這個還挺有意思的,首先跑幾個代碼
1. 這段代碼表示你不要管套幾層try,其實只要弄清楚except下為什么不拋出異常即刻def bar(): a = 10 try:print 1raise except:print 2raise finally:print 3return abar()# 打印(沒有拋出異常): # 2# 32. 這段代碼表示如果finally如果有return語句,則不會拋出異常,沒有return則會拋出異常
def bar(): a = 10 try:print 1raise except:print 2raise finally:print 3# return abar()# 打印(拋出了異常):# 2# Traceback (most recent call last):# 3# File '/Users/xuxin/workplace/DailyScript/segmentfault/file_list_to_dict.py', line 23, in <module># bar()# File '/Users/xuxin/workplace/DailyScript/segmentfault/file_list_to_dict.py', line 18, in bar# raise ValueError()# ValueError3. 我去查了一下,看到了這篇文章深入理解Python的finally
看來f()在拋出異常并后,執行了except中的return,但是并沒有返回到調用者,而是“堅持”將finally中的代碼執行完畢。至此,我算是真正理解了finally的真正含義,就是即使已經return,仍要執行finally中的代碼。
這里我們同樣可以這么理解,在try中如果出現了需要退出方法的語句,但他會努力執行finally,如果finally有return方法,則會立即返回,不會執行之前的退出語句。這個時候,我們可以看看這串代碼
def bar(): a = 10 try:print 1raise finally:print 3return abar()# 打印(沒有拋出異常): # 34.這個時候是不是對finally比較清楚了呢~
現學現賣,如有錯誤,請指出修改~
回答2:要是最后還是拋出了異常,那你的except語句不是白寫了?
相關文章:
