关于try...catch...finally中return的疑惑
关于try...catch...finally里面的return一直是面试的一个热门考点。无非就分以下几个情况:
1、当有finally语句并且try中有return,在执行到return(还未执行)的时候,会先执行finally里面的内容,然后再执行行try中的return。
package com.and.java.demo; public class 测试 { public static void main(String[] args) { System.out.println(new 测试().test()); } public String test() { try { System.out.println("try{...}"); return "try"; } catch (Exception e) { System.out.println("catch{...}"); return "catch"; } finally { System.out.println("finally{...}"); } } }
输出:
try{...} finally{...} try
2、在1的基础上,如果finally里面也有return语句,则try代码块中的return被屏蔽(不执行),即在try中遇到return的时候,会先执行finally里面的内容(包括finally里面的return语句)。
package com.and.java.demo; public class 测试 { public static void main(String[] args) { System.out.println(new 测试().test()); } public String test() { try { System.out.println("try{...}"); return "try"; } catch (Exception e) { System.out.println("catch{...}"); return "catch"; } finally { System.out.println("finally{...}"); return "finally"; } } }
输出:
try{...} finally{...} finally
遇到的问题:
这两种情况想必大家已经掌握。但是还有一种情况,也是我不能理解的地方。一般情况下,在finally里面作一些数据的关闭操作(比如文件,输入/输出流,数据库的关闭),试想一下,要是我们在finally里面对要返回的值进行修改,那会反应到最终的结果上去吗?(因为从上面的讲解可以知道,当try里面有return的时候,它不会立刻执行,会先执行finally里面的内容,然后再执行return)。
package com.and.java.demo; public class 测试 { public static void main(String[] args) { System.out.println(new 测试().test()); } public String test() { String result = ""; try { result = "try"; return result; } catch (Exception e) { result = "catch"; return result; } finally { result = "finally"; } } }
试想一下,它会输出"try" 呢还是"finally"呢?
输出:
try
确实只输出try,但是我们在finally里面是改变了result的值呀?
再进一步改进,判断finally里面的赋值语句是否执行
package com.and.java.demo; public class 测试 { public static void main(String[] args) { System.out.println(new 测试().test()); } public String test() { String result = ""; try { result = "try"; return result; } catch (Exception e) { result = "catch"; return result; } finally { System.out.println("t1->"+result); result = "finally"; System.out.println("t2->"+result); } } }
输出:
t1->try t2->finally try
从输出结果可以看出,finally里面的赋值语句是执行了的,但是在return结果中怎么就没变呢?(目前暂时研究到这个地步,仍没搞明白,还望各位高手指点)