final
1 修饰变量
在修饰基本类型时,表示是一个常量,在定义时必须赋值。
在修饰对象或者数组时,它表示对对象或数组的引用恒定不变,然而对象本身却是可以修改的。
test.chars[2] = 'd';是可以的,因为数组本身是可以修改的。
test.chars = new char[10];会编译报错,因为引用恒定不变。
final String str;
final char[] chars = {'a','b','c'};
public TestFinal(String c){
this.str = c;
}
/**
* @param args
*/
public static void main(String[] args) {
TestFinal test = new TestFinal("a");
test.chars[2] = 'd';
test.chars = new char[10];
}
}
2 修饰方法
把方法锁定,使得在子类(导出类)中不能修改它的含义。
效率,一个final方法被调用时会转为内嵌调用,不会使用常规的压栈方式,使得运行效率较高,尤其是在方法体较简单的情况下。
3 修饰类
声明为final的类不能派生出了子类,也就是不能被继承,一个final类中的所有方法都隐式地指定为final。
因此一个类不能被同事声明成abstract和final。
finalize
Java技术使用finalize()方法在垃圾收集器将对象从内存中清除出去前,做必要的清理工作。这个方法是由垃圾收集器在确定这个对象没有被引用时对这个对象调用的。它是在Object类中定义的,因此所有的类都继承了它。子类覆盖finalize()方法以整理系统资源或者执行其他清理工作。finalize()方法是在垃圾收集器删除对象之前对这个对象调用的。
Java语言规范,不仅不保证终结方法会被及时的执行,而且根本不保证他们会被执行。不应该依赖终结方法来更新重要的状态。
finally
finally是对Java 异常处理模型的最佳补充。finally 结构使代码总会执行,而不管有无异常发生。使用 finally 可以维护对象的内部状态,并可以清理非内存资源。特别是在关闭数据库连接这方面,如果程序员把数据库连接的close()方法放到finally中,就会大大降低程序出错的几率。
public static void main(String[] args) {
try{
return;
}finally{
System.out.println("end");
}
}
finally在return语句之后,跳转到上一级程序之前执行。
因此end是会被输出的。