A股上市公司传智教育(股票代码 003032)旗下技术交流社区北京昌平校区

 找回密码
 加入黑马

QQ登录

只需一步,快速开始

© 杨剑 中级黑马   /  2013-2-25 16:08  /  1866 人查看  /  4 人回复  /   0 人收藏 转载请遵从CC协议 禁止商业使用本文

本帖最后由 杨剑 于 2013-3-18 12:58 编辑

public class Test2 {
        public static void main(String[] args) {
                System.out.println(test());
        }
        public static int test(){
                int x = 1;
                try {
                        return x;
                }finally{
                        x++;
                        System.out.println(x);
                }
        }
        
}
为什么打印结果是2和1,不是1和2

4 个回复

倒序浏览
第一次打印肯定是finally中的x,因为x++变成2,所以打印2
第二次打印函数的返回值,是try中return返回的x,这里注意,虽然在return之前执行了finally并把x赋值为2,
但是return的内容在finally之前是已经确定好的,无论finally怎样改变x,return的x都为1
回复 使用道具 举报
本帖最后由 张文彬 于 2013-2-25 16:21 编辑

因为当调用test()方法时,到return x;test方法并没有结束,
这个方法还没完,还要执行finally块(finally块中语句是必须执行的 )中的语句
而finally块中x++;
                 System.out.println(x);

所以就打印2了,然后test方法结束,因为return x;是在x=1时被返回的。所以返回1,
主函数中就执行打印1.。。。。。。。
回复 使用道具 举报

  1. public class Test2 {
  2.         public static void main(String[] args) {
  3.                 System.out.println(test());                   //方法运行结束出栈才返回x
  4.         }
  5.         public static int test(){
  6.                 int x = 1;
  7.                 try {
  8.                         return x;
  9.                 }finally{                     //程序在执行finally代码块时是把这段代码独立出来,并单独调用的,  所以先于方法调用得到的返回值打印      
  10.                         x++;
  11.                         System.out.println(x);
  12.                 }
  13.         }
  14.         
  15. }
复制代码
回复 使用道具 举报
前一段时间 参加公司的笔试问了这个问题,回来一查才知道当时自己做错了,百思不得其解,上网查到下面的程序,但是运行后发现了错误,我修改后放在了我的blog 上面,希望和大家分享。
经典的java中return和finally问题!

      代码如下:
  1. public      class      Test
  2. {   
  3. public      static      void      main(String[]      args)
  4. {   
  5.      System.out.print(tt());   
  6. }   
  7. public      static      int      tt()
  8. {   
  9.      int      b      =      23;   
  10.      try
  11.      {   
  12.       System.out.println("yes");   
  13.       return      b+=88;   
  14.      }   
  15.      catch(Exception      e)
  16.      {   
  17.       System.out.println("error      :      "      +      e);   
  18.      }   
  19.      finally
  20.      {   
  21.       if(b>25)
  22.       {   
  23.        System.out.println("b>25      :      "+b);   
  24.       }   
  25.       System.out.println("finally");   
  26.      }
  27.      return      b;   
  28. }
  29. }
复制代码
代码说明:
      主要是用来测试return和finally语句到底哪个先执行.在try语句中,返回了b=111; 在finally语句中判断是否大于25,如果大的话就输出大..程序的结果是
yes
b>25        :        111
finally
111
      也就是说明finally语句在return语句执行完了以后才执行的.
      OK,那么问题来了,如果我把finally语句改成这样呢:
finally
     {   
      if(b>25)
      {   
       System.out.println("b>25      :      "+b);   
      }   
      System.out.println("finally");   
      return 100;
     }
             也就是在finally中加入return 语句,返回不同的值. 那么,返回值到底是原来的b值(88),还是新的这个返回值呢? 废话不多,看结果:
yes
b>25        :        111
finally
100
      这样又说明了一个问题,finally语句块里面的return把原来的return给覆盖了!!变成了新的返回值了.
      OK,继续闷骚:我把代码改成这样:
try
     {   
      System.out.println("yes");   
      return      b;   
     }   
     catch(Exception      e)
     {   
      System.out.println("error      :      "      +      e);   
     }   
     finally
     {   
      if(b>25)
      {   
       System.out.println("b>25      :      "+b);   
      }   
      System.out.println("finally");   
      b=100;
     }

            也就是把 try中的返回语句改成返回b值,然后在finally中改变b的值. 那么返回结果到底是原来的b值呢, 还是更改过的b值呢?结果如下:
yes
finally
23
       说明了一个问题,如果finally语句中没有返回语句覆盖的话,那么原来的返回值就不会变,不管你是不是改变了要返回的那个变量.
       最后还是来说说一点点想法,这个机制是不是这样的呢?碰到try语句中的return,那么先把return的值放在某个池中(怎么我也说起池来了,明明根本还不懂的)?       然后执行finally里面的代码块,如果有返回值覆盖语句,就改变先前放在池中的那个值,如果没有,就把那个池中的东西取出来返回出去
回复 使用道具 举报
您需要登录后才可以回帖 登录 | 加入黑马