public class TestTry {
public static void main(String[] args) {
System.out.println(test());//为什么打印 1
}

private static int test()
{
int i = 1;
try {
return i;
} catch (Exception e) {
}
finally
{
i++;
}
return 0;
}
}

解决方案 »

  1.   

    非常简单,因为你定义的test方法 try语句里面执行i=1之后直接就return i这样写就会不执行下面的任何语句,直接退出test方法执行并返回当前的i值,肯定打印输出是1return语句的作用你体会下
      

  2.   

    return语句放在try块里面,先于finally执行,还没等到finally执行,就已经退出这个方法了。
    我建议一般不要把return 放在finally里面,因为与finally一起用的时候会造成语义混乱,不太清晰,程序不容易维护。
      

  3.   

    #1楼 说的很对,你需要先了解一下return的用法
      

  4.   

    嗯,但由于i是声明在方法里面的自动变量,在i++之后就会被丢弃,所以i++实际上浪费了计算资源。还是建议不要这样写了。
      

  5.   

    1.不管出没出现异常,finally块中的语句都会执行;
    2.当try或catch块中有return语句时,finally块中的语句仍会执行;
    3.finally块中的语句是在函数返回前执行的,但函数返回值是在finally块中语句执行前确定的;
    4.finally块中不能包含return语句。 楼主可以自己敲下代码验证下、顺便自己理解下。
      

  6.   

    遇到return语句程序就会退出,不再执行下面的代码,作用类似于break
      

  7.   

    return作用 结束方法 返回值
      

  8.   

    return语句执行了,finally语句始终执行
      

  9.   

    这个问题以前也有个帖子问过,try里面有return会先返回值然后再执行finally语句
      

  10.   

    在try语句中,在执行return语句时,要返回的结果已经准备好了,就在此时程序转到finally执行
    在转去之前,try中先把要返回的结果存放于不同于i的局部变量中,执行完finally之后在从中取出返回结果
    因此,finally中对变量i进行的改变,不会影响返回结果!
      

  11.   

    我受不了了1#真无敌了
    你在finally里面对i++,是在ruturn执行之后才做的
    并不是finally里的内容不做
    但是你return的时候 i是1
    但是你整个程序跑完 i是2记住try catch finally
    finally里面的内容是一定会执行的 所以都在这里处理资源的释放
    面试用的到哦 楼主分拿来把~
      

  12.   

    对。有return.就不会执行后面的语句了。当然打印的是1
      

  13.   


      // Method descriptor #28 ()I
      // Stack: 1, Locals: 4
      private static int test();
         0  iconst_1 // 常量1
         1  istore_0 [i] // 存入寄存器0,即i,以上两行对应 int i = 1
         2  iload_0 [i] // 读取寄存器0,即i
         3  istore_3 // 存入寄存器3,用以之后的return。以上两行对应return i这里,但是仅仅是finally执行之前的部分
         4  iinc 0 1 [i] // 进入finally,对寄存器0,即i,进行+1操作,对应i++
         7  iload_3 // 重新进入return代码部分,读取寄存器3,即刚才存放的用以return的值
         8  ireturn // return
         9  astore_1
        10  iinc 0 1 [i]
        13  goto 22
        16  astore_2
        17  iinc 0 1 [i]
        20  aload_2
        21  athrow
        22  iconst_0
        23  ireturn
          Exception Table:
            [pc: 2, pc: 4] -> 9 when : java.lang.Exception
            [pc: 2, pc: 4] -> 16 when : any
            [pc: 9, pc: 10] -> 16 when : any
          Line numbers:
            [pc: 0, line: 17]
            [pc: 2, line: 19]
            [pc: 4, line: 23]
            [pc: 7, line: 19]
            [pc: 9, line: 20]
            [pc: 10, line: 23]
            [pc: 16, line: 22]
            [pc: 17, line: 23]
            [pc: 20, line: 24]
            [pc: 22, line: 25]
          Local variable table:
            [pc: 2, pc: 24] local: i index: 0 type: int
          Stack map table: number of frames 3
            [pc: 9, full, stack: {java.lang.Exception}, locals: {int}]
            [pc: 16, same_locals_1_stack_item, stack: {java.lang.Throwable}]
            [pc: 22, same]
    另外,不存在finally中的i++不会执行的问题,除非之前有导致jvm崩溃的情况,比如System.exit(0);public class Test {  static int i = 1;  public static void main(String[] args) throws Exception {
        System.out.println(test());
        System.out.println(i);
      }  private static int test() {    try {
          return i;
        } catch (Exception e) {    } finally {
          i++;
        }
        return 0;
      }
    }
    打印
    1
    2
      

  14.   

    也就是说,函数返回值是当时运行到return这行时候整个return 表达式的结果,也就是当时i的值。
    而不是到了return再去执行finally,然后回过头来再去运行return 表达式,求当时(finally以后)表达式的值
      

  15.   

    finally只是退出前运行的代码?不会影响退出
      

  16.   

    这段代码是先执行i=1;给i赋值1后,i的值存在内存中的,然后finnaly块中i++,这时候打印会是2因为i++了,但是return返回的值还是先前存在内存中的1。
      

  17.   

    这个问题很有代表性,执行到return时,应该是直接返回1,但是他还是会去执行finally块里的代码,也就是说此时的i==2 那return是应该返回1还是返回2呢,这才是LZ的疑问吧。
      

  18.   


    finally语句中为什么不能含return语句?这样说是否不是很确切?
    finally中含有return语句,会有警告,并且,这个函数的返回值取finally语句中的返回值而已,没有意义罢了。鄙人愚见
      

  19.   


    finally方法应该在return之后执行