1.final
- final用于声明属性,表示属性不可变
- final用于声明方法,表示方法不可覆写
- final用于声明类,表示类不可被继承
final属性:表示属性不可变。
但是不可变有两重含义:一是引用不可变;二是对象不可变
那么final到底指的是哪种含义呢?
public class Test{
public static void main(String[] args){
final StringBuffer str = new StringBuffer("hello");
str.append(" world");
System.out.println(str);
}
}
运行结果:hello world
public class Test{
public static void main(String[] args){
final StringBuffer str = new StringBuffer("hello");
str = new StringBuffer("world");
}
}
运行结果:编译期间错误
从上述例子可以看出,final指的是引用的不可变性,即它只能指向初始化时指向的那个对象,而不关心指向对象内容的变化。所以被final修饰的变量必须被初始化。一般可以通过以下几种方式对其初始化:
- 在定义时初始化
class Person{
final String name = "zhaomiao";
}
- final成员变量可以在构造块中初始化,但不可以在静态块中初始化
class Person{
final String name ;
{
name = "zhaomiao";
}
}
- 静态final成员变量可以在静态块中初始化,但不可以在构造块中初始化
class Person{
static final String name;
static {
name = "zhaomiao";
}
}
- 在构造方法中初始化,静态final成员变量不可以在构造方法中初始化
class Person{
final String name;
public Person() {
name = "zhaomiao";
}
}
final方法:当一个方法声明为final时,不允许任何子类重写这个方法,但子类仍可以使用这个方法
final参数:用来表示这个参数在这个函数中不允许被修改
final类:当一个类声明为final时,表示此类不能被继承,所有的方法都不能被重写。但是这并不表示final类的成员变量也是不可改变的,要想做到final类的成员变量不可改变,必须给成员变量增加final修饰。一个类不能即被声明为abstract、又被声明为final
2.finally
finally是异常处理的一部分,只能用在try/catch语句中,并且附带了一个语句块,表示这段语句最终一定会执行,经常用于需要释放资源的情况下
Connection conn;
Statement stmt;
try {
conn = DriverManager.getConnection(url1,userName,password);
stmt = conn.createStatement();
stmt.executeUpdate(update);//执行一条更新语句
stmt.close();
conn.close();
}catch(Exception e){
}
在上述的程序中,如果程序在运行过程中没有发现任何异常,那么数据库的连接能到得到释放,程序运行没有问题。
如果在执行某语句时出现异常,后面的close()方法将不会被调用,数据库的连接将不会得到释放。如果这样的程序长期运行,会耗光数据库的连接资源。通过使用finally可以保证任何情况下数据库的连接资源都能够被释放
Connection conn;
Statement stmt;
try {
conn = DriverManager.getConnection(url1,userName,password);
stmt = conn.createStatement();
stmt.executeUpdate(update);//执行一条更新语句
}catch(Exception e){
}finally{
if(stmt != null){
stmt.close();
}
if(conn != null){
conn.close();
}
}
这样不管程序运行是否出现异常finally中的代码一定会执行。这样能够保证在任何情况下,数据库的连接资源都能被释放。
3.finalize
finalize()垃圾回收的用法
finallize是Object类的一个方法,在垃圾回收器执行时会调用被回收对象的finalize()方法,但是需要注意的是,一旦垃圾回收器准备释放对象占用的空间,将首先调用其finalize()方法,并且在下一次垃圾回收动作发生时,才会很正回收对象占用的内存(相当于在第一次垃圾回收时,给该对象一次存活的机会)