trycatchfinallyreturn 执行顺序——超详细讲解
Posted 薛瑄
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了trycatchfinallyreturn 执行顺序——超详细讲解相关的知识,希望对你有一定的参考价值。
转载请标明出处:http://blog.csdn.net/xx326664162/article/details/50266995 文章出自:薛瑄的博客
你也可以查看我的其他同类文章,也会让你有一定的收货!
代码示例:http://www.cnblogs.com/lanxuezaipiao/p/3440471.html
结论:
1、不管有木有出现异常,finally块中代码都会执行;
2、当try和catch中有return时,finally仍然会执行;
3、finally是在return语句执行之后,返回之前执行的(此时并没有返回运算后的值,而是先把要返回的值保存起来,不管finally中的代码怎么样,返回的值都不会改变,仍然是之前保存的值),所以函数返回值是在finally执行前就已经确定了;
4、finally中如果包含return,那么程序将在这里返回,而不是try或catch中的return返回,返回值就不是try或catch中保存的返回值了。
注意:
- finally修改的基本类型是不影响返回结果的。(传值的)
- 修改list ,map,自定义类等引用类型时,是影响返回结果的。(传址的)对象也是传址的
但是date类型经过测试是不影响的。有点奇怪。
举例:
情况1: try catch()finally return;
显然程序按顺序执行。
情况2: try return; catch() finally return;
- 先执行try块中return 语句(包括return语句中的表达式运算),但不返回;
- 执行finally语句中全部代码
- 最后执行try中return 返回
- finally块之后的语句return不执行,因为程序在try中已经return。
情况3: try catch()return; finally return;
1、程序先执行try,如果遇到异常执行catch块,
- 有异常:
- 执行catch中return语句,但不返回
- 执行finally语句中全部代码,
- 最后执行catch块中return返回。 finally块后的return语句不再执行。
- 无异常:执行完try再finally再return…
情况4: try return; catch() finallyreturn;
- 执行try块return语句(包括return语句中的表达式运算),但不返回;
- 再执行finally块,
- 执行finally块,有return,从这里返回。
此时finally块的return值,就是代码执行完后的值
情况5: try catch()return;finallyreturn;
- 程序执行catch块中return语句(包括return语句中的表达式运算),但不返回;
- 再执行finally块,
- 执行finally块,有return,从这里返回。
情况6: try return;catch()return; finallyreturn;
1、程序执行try块中return语句(包括return语句中的表达式运算),但不返回;
-
有异常:
- 执行catch块中return语句(包括return语句中的表达式运算),但不返回;
- 再执行finally块
- 执行finally块,有return,从这里返回。
-
无异常:
-
再执行finally块
-
执行finally块,有return,从这里返回。。
最终结论:
- 任何执行try 或者catch中的return语句之后,在返回之前,如果finally存在的话,都会先执行finally语句,
- 如果finally中有return语句,那么程序就return了,所以finally中的return是一定会被return的,
- 编译器把finally中的return实现为一个warning。
重要提示:
从finally中返回会导致异常丢失 参考:Can we use “return” in finally block [duplicate]
参考:http://blog.csdn.net/kavensu/article/details/8067850
关注我的公众号,轻松了解和学习更多技术
以上是关于trycatchfinallyreturn 执行顺序——超详细讲解的主要内容,如果未能解决你的问题,请参考以下文章
java try catch finally return执行顺序
python pymysql 执行比较时间的sql语句,在mysql中可以顺了执行,但是在python中执行为何报错?