说在前面,每天积累一点点,详情请点击github
final
final是可以修饰域,参数,方法,类的关键字。
final修饰域时,一方面被static和final修饰表示常量。在Java中被static和final修饰的域只占用一段不可改变的存储空间。另一方面被final表示初始化后不可改变的域,如果是引用,则表示引用不能指向其他。因数组是一个对象,故也是一个引用。
public class FinalDomain {
private static final int VALUE = 99;
private final Integer a = 3;
private final int[] array = {1, 2, 3};
public static void main(String[] args) {
// TODO Auto-generated method stub
FinalDomain fd = new FinalDomain();
System.out.println(VALUE);
//fd.a = 2; //如果去掉注释的话,这句话就会报错,因为 final引用不可以被修改
int[] x = {5, 6, 7};
//fd.array = x;//如上所释
}
}
final作用于形参中时,如果是基本数据类型,则不允许在方法中更改。如果是引用,则在方法中不允许更改引用,但是可以更改引用中的成员变量。
class Number {
int n = 3;
}
public class FinalArgs {
public void update(final int i) {
//i++; //如果把注释去掉,则报异常,因被final修饰的基本类型不可以在方法中被修改
}
public void update(final Number num) {
//num = new Number(); //如果把注释去掉,则报异常,因被final修饰的引用不可以在方法中被修改
num.n++;// 然而可以修改数据成员。
}
}
空白final是指被final修饰但未给定初值的域。这种域必须在构造方法里完成初始化。
有关final变量的初始化小结:
- 在定义变量时赋初值
- 空白final一定要在构造器中初始化,否则编译不通过
- static final域可以在定义时,静态代码块中初始化,不能在构造方法中初始化
- final域可以定义,非静态代码块,构造方法中初始化,不能在静态代码块中初始化
final修饰方法时,一般目的就是禁止子类覆盖其父类的行为,保持父类一些 原有的特性。
final修饰修饰类时,一般目的就是禁止被继承。
使用final的好处:
- final关键字提高了性能。JVM和Java应用都会缓存final变量
- final变量可以安全的在多线程环境下进行共享,而不需要额外的同步开销
- 使用final关键字,JVM会对方法、变量及类进行优化
finally
finally是异常处理语句结构的一部分,表示总是执行。无论异常是否抛出,finally代码块总是被执行。当没有catch语句并抛出异常时,finally也依然会执行。finally的主要作业是释放资源。比如IO缓冲区,数据库连接等。
finalize
finalize是Object类的一个方法,在垃圾回收集器执行的时候会调用被回收对象的此方法,可以覆盖此方法提供垃圾回收集时的其他资源回收,例如关闭文件等。JVM不保证此方法总被调用。