python - 為什么這段代碼沒有異常拋出?
問題描述
In [8]: def bar(): ...: a = 10 ...: try: ...: raise ...: except: ...: try: ...: raise ...: except: ...: raise ...: finally: ...: return aIn [9]: bar()Out[9]: 10
問題解答
回答1:這個(gè)還挺有意思的,首先跑幾個(gè)代碼
1. 這段代碼表示你不要管套幾層try,其實(shí)只要弄清楚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()在拋出異常并后,執(zhí)行了except中的return,但是并沒有返回到調(diào)用者,而是“堅(jiān)持”將finally中的代碼執(zhí)行完畢。至此,我算是真正理解了finally的真正含義,就是即使已經(jīng)return,仍要執(zhí)行finally中的代碼。
這里我們同樣可以這么理解,在try中如果出現(xiàn)了需要退出方法的語句,但他會努力執(zhí)行finally,如果finally有return方法,則會立即返回,不會執(zhí)行之前的退出語句。這個(gè)時(shí)候,我們可以看看這串代碼
def bar(): a = 10 try:print 1raise finally:print 3return abar()# 打印(沒有拋出異常): # 34.這個(gè)時(shí)候是不是對finally比較清楚了呢~
現(xiàn)學(xué)現(xiàn)賣,如有錯(cuò)誤,請指出修改~
回答2:要是最后還是拋出了異常,那你的except語句不是白寫了?
相關(guān)文章:
1. 關(guān)docker hub上有些鏡像的tag被標(biāo)記““This image has vulnerabilities””2. docker-compose中volumes的問題3. boot2docker無法啟動4. nignx - docker內(nèi)nginx 80端口被占用5. docker安裝后出現(xiàn)Cannot connect to the Docker daemon.6. dockerfile - 為什么docker容器啟動不了?7. docker容器呢SSH為什么連不通呢?8. node.js - antdesign怎么集合react-redux對input控件進(jìn)行初始化賦值9. java - SSH框架中寫分頁時(shí)service層中不能注入分頁類10. 關(guān)于docker下的nginx壓力測試

網(wǎng)公網(wǎng)安備