首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

Java finally语句到底是在return之前还是之后执行?

1. finally语句在return语句执行之后return返回之前执行的。...里加上return过后,finally外面的return b就变成不可到达语句了,也就是永远不能被执行到,所以需要注释掉否则编译器报错。...这同时也说明了返回语句是try中的return语句而不是finally外面的return b;这句,不相信的话可以试下,将return b;改为return 294,对原来的结果没有一点影响。...4. try块里的return语句在异常的情况下不会被执行,这样具体返回哪个看情况。...最后总结:finally块的语句在try或catch中的return语句执行之后返回之前执行且finally里的修改语句不能影响try或catch中return已经确定的返回值,若finally里也有return

1.3K20
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    Java finally 语句到底是在 return 之前还是之后执行?

    ,那么原来的返回值可能因为finally里的修改而改变也可能不变 4 try块里的return语句在异常的情况下不会被执行,这样具体返回哪个看情况 5 当发生异常后,catch中的return执行情况与未发生异常时...里的return直接返回了,就不管try中是否还有返回语句,这里还有个小细节需要注意,finally里加上return过后,finally外面的return b就变成不可到达语句了,也就是永远不能被执行到...这同时也说明了返回语句是try中的return语句而不是 finally外面的return b;这句,不相信的话可以试下,将return b;改为return 294,对原来的结果没有一点影响。...4 try块里的return语句在异常的情况下不会被执行,这样具体返回哪个看情况 public class FinallyTest4 { public static void main(String...6 最后总结 finally块的语句在try或catch中的return语句执行之后返回之前执行且finally里的修改语句可能影响也可能不影响try或catch中 return已经确定的返回值,若finally

    1.2K10

    Java finally语句到底是在return之前还是之后执行?

    finally语句在return语句执行之后return返回之前执行的。...里的return直接返回了,就不管try中是否还有返回语句,这里还有个小细节需要注意,finally里加上return过后,finally外面的return b就变成不可到达语句了,也就是永远不能被执行到...这同时也说明了返回语句是try中的return语句而不是 finally外面的return b;这句,不相信的话可以试下,将return b;改为return 294,对原来的结果没有一点影响。...try块里的return语句在异常的情况下不会被执行,这样具体返回哪个看情况。...最后总结: finally块的语句在try或catch中的return语句执行之后返回之前执行且finally里的修改语句可能影响也可能不影响try或catch中 return已经确定的返回值,若finally

    81620

    Java finally语句到底是在return之前还是之后执行?

    1. finally语句在return语句执行之后return返回之前执行的。...里的return直接返回了,就不管try中是否还有返回语句,这里还有个小细节需要注意,finally里加上return过后,finally外面的return b就变成不可到达语句了,也就是永远不能被执行到...这同时也说明了返回语句是try中的return语句而不是 finally外面的return b;这句,不相信的话可以试下,将return b;改为return 294,对原来的结果没有一点影响。...4. try块里的return语句在异常的情况下不会被执行,这样具体返回哪个看情况。...最后总结 finally块的语句在try或catch中的return语句执行之后返回之前执行且finally里的修改语句可能影响也可能不影响try或catch中 return已经确定的返回值,若finally

    78220

    try {}里有一个return语句,那么紧跟在这个try后的finally {}里的code会不会被执行,什么时候被执行,还是在return之后执行?

    这是一个很有趣的问题,我测试的结果是:是在return中间执行。...我在网上搜寻了一些资料,下面是参考代码: 1 /** 2 * 3 */ 4 package com.b510.test; 5 6 /** 7 * try {}里有一个return...语句,那么紧跟在这个try后的finally {}里的code会不会被执行,什么时候被执行,还是在return之后执行?...} 29 } 输出结果: try里面的i : 1 进入finally... fianlly里面的i : 2 结果: 1 下面是我在debug时,抓取的图片: ?...上图是程序执行到了try模块中的return语句时,按下F5键,进入到finally模块,执行finally模块中的语句后,变量"i"的值发生了变化。 ?

    1.2K30

    XDM,JS如何函数式编程?看这就够了!(一)

    比如:你可能写过一些命令式的代码,像 if 语句和 for 循环这样的语句。这些语句旨在精确地指导计算机如何完成一件事情。...(这么做的原因是多方面的,后续会一一介绍) 这里,输入值就是函数传参,输出值就是return的东西。...相比在函数中提早使用 return,我们更应该用常用的流控制( if 逻辑 )来控制 retValue 的赋值。到最后,我们 return retValue。...其中最强大的就是:【闭包】。 我们将在的后续举例中大量使用闭包。它可能是所有函数式编程中最重要的基础。...它可分为两类:偏函数应用和柯里化。后续会展开。 具名函数 我们提倡要用具名函数,而不是匿名函数,这更有利于我们语义化代码,比如getPreferredName(..)

    43030

    Generator:化异步为同步

    我在第一话里提到,异步和同步之间的鸿沟在于:同步语句的执行时机是“现在”,而异步语句的执行时机在“未来”。...为了填平鸿沟,如果一个异步操作要写成同步的形式,那么同步代码就必须有“等待”的能力,等到“未来”变成“现在”的那一刻,再继续执行后面的语句。 在不阻塞主线程的前提下,这可能吗? 听起来不太可能。...对于引用类型的数据,在栈帧里只保存引用,而真正的数据存放在堆(Heap)里。...首先,最后一行it.next()使得Generator内部的代码从头开始执行,执行到yield语句时,暂停,此时可以把yield想象成return,Generator的栈帧需要被弹出,会先计算yield...也就是说,在Generator里使用try-catch语句捕获异步错误,不再是梦!

    1.5K70

    自制Monkey语言编译器:解释执行return语句和错误处理控制

    if里面的return语句执行后,把整形10返回给最外层,完成本节代码后,编译器对上面代码解释执行的结果如下: ?...在return语句后面很可能是一个复杂的运算表达式,所以代码先递归调用eval解释执行return后面的语句以便获得要返回的数据对象,接着把该数据对象封装在前面设计的ReturnValues符号对象里。...if语句块里面的每条代码都解释执行一遍,然后把最后一条语句解释执行的结果返回给上一层,这样的话编译器在解释执行开头给出的代码时,它会解释执行最外层if语句块最后一条语句后才停止,于是使用上面代码解释执行...例如return后面的表达式,if括号里面的条件判断表达式,他们在解释执行时都可能产生错误,因此我们需要在相应的位置进行监控: eval(node){ .......condition } .... } 代码在执行if语句块前,先判断if括号里的条件表达式在解释执行时是否正常,如果有错就不再往下执行,完成上面代码后,编译器就基本建立了语法上的错误检测机制

    72550

    js那些事

    操作步骤如下: 1.仍然是在227行打上断点 → 2. 点击加载更多按钮 → 3. 单击一次“逐语句执行“按钮,js代码执行到228行 → 4.用鼠标选中i++(什么叫选中大家里不理解?...在console下方的输入栏里输入i → 6. 按enter回车键即可。...上面的第二种方法里,提到了console这个东西,我们可以称呼它为控制台或者其他什么都可以,这不重要~console的功能很强大,在调试的过程中,我们往往需要知道某些变量的值到底输出了什么,或者我们使用选择器...很简单,console本身就是一个js解析器,$(“.xxx”)就是一个js语句,所以自然console能够解析这个语句然后输出结果。...假设上图我只在227行打了个断点,然后一直点击逐语句执行”按钮到229行,这时候如果再点击一次“逐语句执行”按钮呢?则会进入下图的js里: ?

    1.3K30

    探索异步迭代器在 Node.js 中的使用

    本文也是探索异步迭代器在 Node.js 中的都有哪些使用场景,欢迎留言探讨。...Node.js Stream 模块的可读流对象在 v10.0.0 版本试验性的支持了 [Symbol.asyncIterator] 属性,可以使用 for await...of 语句遍历可读流对象,在.../hello.txt', { encoding: 'utf-8', highWaterMark: 1 }); 以往当我们读取一个文件时,需要监听 data 事件,拼接数据,在 end 事件里判断完成......of 语句在循环内部会默认调用可迭代对象 readable 的 Symbol.asyncIterator() 方法得到一个异步迭代器对象,之后调用迭代器对象的 next() 方法获取结果。...使用 for await...of 遍历可迭代对象 cursor 还是基于我们上面的示例,如果换成 for await...of 语句遍历就简单的多了。

    7.5K20

    React学习(二)-深入浅出JSX

    ,一切皆js,对于在JS里面写HTML代码,刚开始是非常反感的,甚至有违背当初的原则 但是,对于原先那种仅仅是把三种语言技术放在了三种不同文件位置里进行分开管理了,实际上,它并没有实现逻辑上的分离 既然前端...全称: javascript and XML 定义: 可拓展(自定义)标记性语言,基于javascript,融入了XML,我们可以在js中书写xml,使用JSX可以很好的描述UI在页面中应该呈现它应有的交互形式...实现组件化的好处,不言而喻,下面来看看React的JSX是怎么样的 当你用create-react-app脚手架,初始化一个react应用后,在入口文件index.js中最后一行代码,ReactDOM.render...中嵌入表达式{ 表达式 } 双大括号内可以是变量,字符串,数组,函数调用, 但是不可以是对象,也不支持 if,for语句 例如:你在插值表达式里写对象:它是会报错的 { {name: "川川", age...里面写if,for语句也是会报错的 { if(this.isBtn) { } 其实,JSX 也是一个表达式,它虽然不支持if,for语句,但是它在

    2K30

    React基础(2)-深入浅出JSX

    前言 在Jq,原生javascript时期,在写页面时,往往强调的是内容结构,层叠样式,行为动作要分离,三者之间分工明确,不要耦合在一起 然而在React出现后,一切皆js,对于在JS里面写HTML代码...实现组件化的好处,不言而喻,下面来看看React的JSX是怎么样的 当你用create-react-app脚手架,初始化一个react应用后,在入口文件index.js中最后一行代码,ReactDOM.render...中嵌入表达式{ 表达式 } 双大括号内可以是变量,字符串,数组,函数调用, 但是不可以是对象,也不支持 if,for语句 例如:你在插值表达式里写对象:它是会报错的 { {name: "川川", age...里面写if,for语句也是会报错的 { if(this.isBtn) { } 其实,JSX 也是一个表达式,它虽然不支持if,for语句,但是它在if...UI界面显示什么样,取决于JSX对象结构,换句话说,取决于render()函数里面的return关键字后面返回的JSX内容结构 引入React.js库是为了解析识别JSX语法,同时创建虚拟DOM,而引入

    2.4K00

    前端异常的捕获与处理

    只要代码中包含 finally 子句,则无论 try 或 catch 语句中包含什么代码——甚至是 return 语句,都不会阻止 finally 子句执行。...} finally { return "做作业"; } return "睡觉"; } 表面上调用这个函数会返回 "出去玩",因为返回 "出去玩" 的语句位于 try 语句块中,而执行此语句又不会出错...实际上返回 "做作业",因为最后还有 finally 子句,结果就会导致 try 块里的 return 语句被忽略,也就是说调用的结果只能返回 "做作业"。...; } 任何错误处理策略中最重要的一个部分,就是确定错误是否致命。...,但如果每个请求方法都需要写一遍跳转登录页的逻辑就很麻烦了,这时候就会考虑使用 axios 的拦截器来做统一梳理,同理能统一处理的异常也可以在放在拦截器里处理。

    3.5K30
    领券