关于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结果中怎么就没变呢?(目前暂时研究到这个地步,仍没搞明白,还望各位高手指点)

posted @ 2012-04-17 15:15  And.He  阅读(7766)  评论(12编辑  收藏  举报