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

 找回密码
 加入黑马

QQ登录

只需一步,快速开始

Mrliu666

初级黑马

  • 黑马币:18

  • 帖子:6

  • 精华:0

来黑马学习了这么久,分享一下个毕业后可能会遇到的高频面试题吧!

final,finally,finalize的区别
final
Final可以用于成员变量(包括方法参数),方法、类。
Final成员
作为变量
变量一旦被初始化便不可改变(对于基本类型,指的是值不变;对于对象类型,指的是引用不变),初始化只可能在两个地方:定义处和构造函数。
作为方法参数
对于基本类型,定义成final参数没有什么意义,因为基本类型就是传值,不会影响调用语句中的变量;
对于对象类型,在方法中如果参数确认不需要改变时,定义成final参数可以防止方法中无意的修改而影响到调用方法。
Final方法
不可覆写
编译器将对此方法的调用转化成行内(inline)调用,即直接把方法主体插入到调用处(方法主体内容过多的时候反而会影响效率)
Final类
不可继承

finalize

类的Finalize方法,可以告诉垃圾回收器应该执行的操作,该方法从Object类继承而来。
在从堆中永久删除对象之前,垃圾回收器调用该对象的Finalize方法。
注意,无法确切地保证垃圾回收器何时调用该方法,也无法保证调用不同对象的方法的顺序。
即使一个对象包含另一个对象的引用,或者在释放一个对象很久以前就释放了另一个对象,
也可能会以任意的顺序调用这两个对象的Finalize方法。如果必须保证采用特定的顺序,则必须提供自己的特有清理方法。

finally
异常处理关键字,finally中的主体总会执行,不管异常发生是否。
2.1、当try中有return时执行顺序
return语句并不是函数的最终出口,如果有finally语句,这在return之后还会执行finally
(return的值会暂存在栈里面,等待finally执行后再返回)
2.2 return和异常获取语句的位置,具体情况如以下代码演示:

return和异常获取语句的位置情况一(try中有return,finally中没有return)
演示代码:

public class finallyDemo1 {
public static void main(String[] args) {
   
    System.out.println(test());
}
private static int test() {
    int num = 10;
    try {
        System.out.println("try");
        return num += 80;
    } catch (Exception e) {

    } finally {
        if (num > 20) {
            System.out.println("num > 20"+":"+num);
        }
        System.out.println("finally");
    }
    return num;
}
}
输出结果:

出现该结果的原因是:
“return num += 80”被拆分成了“num = num+80”和“return num”两个语句,先执行try中的“num =num+80”语句,将其保存起来,在try中的”return num“执行前,先将finally中的语句执行完,而后再将90返回。

return和异常获取语句的位置情况二(try和finally中均有return)
代码演示:

public class finallyDemo2 {
    public static void main(String[] args) {
        System.out.println(test());
    }

    // try中的return被”覆盖“掉了,不再执行。
    private static int test() {
        int num = 10;
        try {
            System.out.println("try");
            return num += 80;
        } catch (Exception e) {

        } finally {
            if (num > 20) {
                System.out.println("num > 20"+":"+num);
            }
            System.out.println("finally");
            return 100;
        }
    }
}
输出结果:

出现该结果的原因是: try中的return被"覆盖"掉了,不再执行。

return和异常获取语句的位置情况三(finally中改变返回值num)
代码演示:

public class finallyDemo3 {
    public static void main(String[] args) {
        System.out.println(test());
    }
   
    private static int test() {
        int num = 10;
        try {
            System.out.println("try");
            return num;
        } catch (Exception e) {

        } finally {
            if (num > 20) {
                System.out.println("num > 20"+":"+num);
            }
            System.out.println("finally");
            num = 100;
        }
        return num;
    }
}
输出结果:

出现该结果的原因是:
**虽然在finally中改变了返回值num,但因为finally中没有return该num的值,因此在执行完finally中的语句后,test()方法会得到try中返回的num的值,而try中的num的值依然是程序进入finally代码块前保留下来的值,因此得到的返回值为10。并且函数最后面的return语句不会执行。

return和异常获取语句的位置情况三另外一种情况:将num的值包装在Num类中
代码演示:

public class finallyDemo4 {

    public static void main(String[] args) {
        
        System.out.println(test().num);
    }

    private static Num test() {
        Num number = new Num();
        try {
            System.out.println("try");
            return number;
        } catch (Exception e) {

        } finally {
            if (number.num > 20) {
                System.out.println("number.num > 20"+":"+number.num);
            }
            System.out.println("finally");
            number.num = 100;
        }
        return number;
    }
}

class Num {
    public int num = 10;
}
输出结果:

return和异常获取语句的位置简单地总结如下:
try语句在返回前,将其他所有的操作执行完,保留好要返回的值,而后转入执行finally中的语句,而后分为以下三种情况:
情况一:如果finally中有return语句,则会将try中的return语句”覆盖“掉,直接执行finally中的return语句,得到返回值,这样便无法得到try之前保留好的返回值。
情况二:如果finally中没有return语句,也没有改变要返回值,则执行完finally中的语句后,会接着执行try中的return语句,返回之前保留的值。
情况三:如果finally中没有return语句,但是改变了要返回的值,这里有点类似与引用传递和值传递的区别,分以下两种情况:
如果return的数据是基本数据类型,则在finally中对该基本数据的改变不起作用,try中的return语句依然会返回进入finally块之前保留的值。
如果return的数据是引用数据类型,而在finally中对该引用数据类型的属性值的改变起作用,try中的return语句返回的就是在finally中改变后的该属性的值。





0 个回复

您需要登录后才可以回帖 登录 | 加入黑马