为什么这段代码没有异常抛出?

发布于 2022-09-04 17:28:36 字数 291 浏览 27 评论 0

In [8]: def bar():
   ...:     a = 10
   ...:     try:
   ...:         raise
   ...:     except:
   ...:         try:
   ...:             raise
   ...:         except:
   ...:             raise
   ...:     finally:
   ...:         return a


In [9]: bar()
Out[9]: 10

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(2

北斗星光 2022-09-11 17:28:36

这个还挺有意思的,首先跑几个代码

1. 这段代码表示你不要管套几层try,其实只要弄清楚except下为什么不抛出异常即刻
def bar():
    a = 10
    try:
        print 1
        raise
    except:
        print 2
        raise
    finally:
        print 3
        return a

bar()
# 打印(没有抛出异常): 
# 2
# 3
2. 这段代码表示如果finally如果有return语句,则不会抛出异常,没有return则会抛出异常
def bar():
    a = 10
    try:
        print 1
        raise
    except:
        print 2
        raise
    finally:
        print 3
        # return a
bar()
# 打印(抛出了异常):
# 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()
# ValueError
3. 我去查了一下,看到了这篇文章深入理解Python的finally

看来f()在抛出异常并后,执行了except中的return,但是并没有返回到调用者,而是“坚持”将finally中的代码执行完毕。至此,我算是真正理解了finally的真正含义,就是即使已经return,仍要执行finally中的代码。

这里我们同样可以这么理解,在try中如果出现了需要退出方法的语句,但他会努力执行finally,如果finally有return方法,则会立即返回,不会执行之前的退出语句。
这个时候,我们可以看看这串代码

def bar():
    a = 10
    try:
        print 1
        raise
    finally:
        print 3
        return a

bar()
# 打印(没有抛出异常): 
# 3
4.这个时候是不是对finally比较清楚了呢~

现学现卖,如有错误,请指出修改~

囍孤女 2022-09-11 17:28:36

要是最后还是抛出了异常,那你的except语句不是白写了?

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文