今天继续看看Java基础部分的八股文。
Java 中的final 关键字有哪些用法?
- (1)修饰类:表示该类不能被继承;
- (2)修饰方法:表示方法不能被重写;
- (3)修饰变量:表示变量只能一次赋值以后值不能被修改(常量) 。
try-finally
try{}里有一个return 语句,那么紧跟在这个try 后的finally{}里的代码会不会被执行,什么时候被执行?
答案是会执行,会在return返回之前执行。尽管try中的return 语句不会立马返回调用者,而是记录下返回值(这里的可能是地址也可能是基本数据类型)待finally 代码块执行完毕之后再向调用者返回其值,然后如果在finally 中修改了返回值,就会返回修改后的值。
包装类型和基本数据类型是不一样的,举个最简单的例子
public ArrayList get() {
ArrayList arrayList = new ArrayList();
arrayList.add("hello");
try {
return arrayList;
}finally {
arrayList.clear();
}
}
上面的例子会返回同一个arrayList,但是由于finally中的clear(),所以最后size是0
public int get() {
int i = 12;
try {
return i;
}finally {
i++;
}
}
但是这里返回值则是之前的12而不是13.
那么如果finally中还有另外一个return呢? 答案是会根据finally中的return值返回。
运行时异常与受检异常有何异同?
异常表示程序运行过程中可能出现的非正常状态, 运行时异常表示虚拟机的通常
操作中可能遇到的异常,是一种常见运行错误,只要程序设计得没有问题通常就
不会发生。受检异常跟程序运行的上下文环境有关,即使程序设计无误, 仍然可
能因使用的问题而引发。Java 编译器要求方法必须声明抛出可能发生的受检异常,
但是并不要求必须声明抛出未被捕获的运行时异常。异常和继承一样,是面向对
象程序设计中经常被滥用的东西,在Effective Java 中对异常的使用给出了以下指
导原则:
- 不要将异常处理用于正常的控制流(设计良好的API 不应该强迫它的调
用者为了正常的控制流而使用异常) - 对可以恢复的情况使用受检异常,对编程错误使用运行时异常
- 避免不必要的使用受检异常(可以通过一些状态检测手段来避免异常的发生)
优先使用标准的异常 - 每个方法抛出的异常都要有文档
- 保持异常的原子性
- 不要在catch 中忽略掉捕获到的异常
List、Set、Map 和 Collection 接口
List、Set继承自Collection接口,而Map没有。
- Map是键值对映射容器,与List 和Set 有明显的区别,
- Set 存储的零散的元素且不允许有重复元素( 数学中的集合也是如此),
- List是线性结构的容器,适用于按数值索引访问元素的情形。