2012年4月17日星期二

关于try...catch...finally中return的疑惑

关于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->tryt2->finallytry

从输出结果可以看出,finally里面的赋值语句是执行了的,但是在return结果中怎么就没变呢?(目前暂时研究到这个地步,仍没搞明白,还望各位高手指点)



TAG:java try catch finally return