• 关于Java中try-catch-finally-return语句的思考


      我们知道return语句用在某一个方法中,一是用于返回函数的执行结果,二是用于返回值为void类型的函数中,仅仅是一个return语句(return ;),此时用于结束方法的执行,也即此return后的语句将不会被执行,当然,这种情况下return语句后不能再有其它的语句了。 

        public static int print() {
            int c = 1;
            try {
                c++;
                System.out.println("try执行中...");
                return c+100; //--------1
            } catch (Exception e) {
                e.printStackTrace();
    //return c; //--------4 }
    finally { c++; System.out.println("finally执行中..."); return c; //--------2 } //return c; //---------3 }

      程序执行的结果为:

    run:
    try执行中...
    finally执行中...
    3
    成功构建 (总时间: 0 秒)

      注意,2与3位置处的return语句只能有一个,并且2、3、4中必须有一个return语句,如果2出执行后方法就结束了,3处的语句得不到执行。

       try语句块执行到1处时,会将会将函数的返回值存放到另外一个临时变量(不同与c的变量,它的值为102)中,由于未发生异常,紧接着将会执行finally语句块,2处又遇到一个语句块,并将返回值存放到临时变量(值为3)中,最终返回的是此处的临时变量的值,此处return执行完成后,该方法结束。  

      public static int print() {
            int c = 1;
            try {
                c++;
                System.out.println(c);
                System.out.println("try");
                return c+100; //--------1
            }finally {
                c++;
                System.out.println(c);
                System.out.println("finally");
               
            }
        }

      上述代码中finally语句块中没有return语句,函数最终返回的是第一个临时变量的值,也即102,执行结果如下:

    run:
    try
    finally
    102
    成功构建 (总时间: 0 秒)
  • 相关阅读:
    MySQL 元数据
    MySQL 复制表
    MySQL 临时表
    MySQL 索引
    MySQL ALTER
    MySQL 事务
    MySQL 正则表达式
    Mysql Join
    Python(数据库之表操作)
    Python知识点复习之__call__
  • 原文地址:https://www.cnblogs.com/yueliming/p/3470694.html
Copyright © 2020-2023  润新知