博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Java | try-catch-finally-return执行顺序
阅读量:4089 次
发布时间:2019-05-25

本文共 1267 字,大约阅读时间需要 4 分钟。

1. try中没有抛出异常,try、catch和finally块中都有return语句

640?wx_fmt=png

运行结果:

640?wx_fmt=png

执行顺序:执行try块,执行到return语句时,先执行return的语句,--i,但是不返回到main方法,执行finally块,遇到finally块中的return语句,执行--i,并将值返回到main方法,这里就不会再回去返回try块中计算得到的值。

结论:try-catch-finally都有return语句时,没有异常时,返回值是finally中的return返回的。

2. try中没有抛出异常,仅try和catch中有return语句

640?wx_fmt=png

执行结果:

640?wx_fmt=png

执行顺序:try中执行完return的语句后,不返回,执行finally块,finally块执行结束后,返回到try块中,返回i在try块中最后的值。

结论:try-catch都有return语句时,没有异常时,返回值是try中的return返回的。

3. try中有抛出异常,try、catch和finally块中都有return语句

640?wx_fmt=png

运行结果:

640?wx_fmt=png

执行顺序:抛出异常后,执行catch块,在catch块的return的--i执行完后,并不直接返回而是执行finally,因finally中有return语句,所以执行返回结果6。

结论:try块中抛出异常,try、catch和finally中都有return语句,返回值是finally中的return。

4. try中有抛出异常,try、catch中都有return语句

640?wx_fmt=png

执行结果:

640?wx_fmt=png

执行顺序:抛出异常后,执行catch块,执行完finally语句后,依旧返回catch中的执行return语句后的值,而不是finally中修改的值。

结论:返回的catch中return值。

5. try、catch中有抛出异常,finally中有return语句

640?wx_fmt=png

运行结果:

640?wx_fmt=png

执行顺序:try块中出现异常到catch,catch中出现异常到finally,finally中执行到return语句返回,不检查异常。

结论:返回finally中return值。

6. try-catch-finally外有return语句

640?wx_fmt=png

运行结果:

640?wx_fmt=png

执行顺序:try块中出现异常到catch,再到finally中执行到,最后return --i。

结论:返回try-catch-finally外的return值。

总结:

结论一:

return语句并不是函数的最终出口,如果有finally语句,这在return之后还会执行finally(return的值会暂存在栈里面,等待finally执行后再返回)。结论二:

finally里面不建议放return语句,根据需要,return语句可以放在try和catch里面和函数的最后:   (1)return语句只在函数最后出现一次。   (2)return语句仅在try和catch里面都出现。   (3)return语句仅在try和函数的最后都出现。   (4)return语句仅在catch和函数的最后都出现。

转载地址:http://ksbii.baihongyu.com/

你可能感兴趣的文章
Vue ElementUI el-collapse 改造:手风琴
查看>>
1.项目初始化
查看>>
2.申请 Cesium Ion 密钥
查看>>
3.场景初始化
查看>>
4.获取鼠标移动位置
查看>>
0.各类资料
查看>>
5.WMTS 调用
查看>>
6.3dtiles 调用
查看>>
组件化:局部批量引入示例组件
查看>>
使用 Vuepress 创建自己的技术文档站
查看>>
工具:Nginx
查看>>
7.WMS 调用
查看>>
8.Terrain 调用
查看>>
组件:组件、方法和指令导出
查看>>
window.onresize 与 window.addEventListener(‘resize‘,...) 区别
查看>>
Vue 中添加拖动指令
查看>>
Vuepress CSS 样式覆盖:修改内容宽度
查看>>
《Leaflet 基础知识点》- 鼠标点击事件获取坐标点
查看>>
《Leaflet 基础知识点》- 地图定位、跳转和缩放
查看>>
《Leaflet 基础知识点》- 计算两点距离
查看>>