final
修饰符(关键字)如果一个类被声明为final
,意味着它不能再派生出新的子类,不能作为父类被继承。因此一个类不能既被声明为 abstract
的,又被声明为final
的。将变量或方法声明为final,可以保证它们在使用中不被改变。被声明为final
的变量必须在声明或者初始化块、构造器等给定初值,而在以后的引用中只能读取,不可修改。
1. final类
final
修饰的类不能够被继承,也就不会有子类。
2. final方法
final
修饰的方法是不能够被重写的。
但是存在一个特殊的情况,当父类中的方法同时被final
private
修饰时,在子类中时可以有同名方法的。因为当父类方法被private
修饰的时候,子类是访问不到这个方法,在子类看来,父类的这个方法是不存在的,所以子类中可以产生一个与父类同名的方法,这两个方法之间是没有任何关系的。
此外,final
修饰的方法只是不能够被重写,但是能够被重载。
class Fruit{
final static public void test() {
System.out.println("这是没有被子类覆盖的方法");
}
}
public class Banana extends Fruit{
public void test() { //此处报错,被重写的方法不能够是final修饰的方法
}
final public static void call(final String name) {
System.out.println("正在拨打" + " " + name + "的电话");
}
final public static void call(int num) { //此处无报错,说明final方法是可以被重载的
System.out.println("这是被重载的方法");
}
public static void main(String[] args) {
}
}
3. final变量
- final成员变量
类变量必须在静态初始化块或者声明时指定初始值,两个地方选择一个。
实例变量必须在非静态初始化块、构造器、声明时指定初始值,三者之间选择一个。
- final局部变量
局部变量既可以在定义的时候指定初始值,也可以在后面代码中指定初始值,两个位置只能选择一次。此外当方法的形参使用final修饰的时候,由系统传入的参数进行初始化,在方法内部不能够对该参数重新赋值。
static public void call(final String name) {
System.out.println("正在拨打" + " " + name + "的电话");
name = "一个名字"; //此处赋值出错
}
finally
finally
块一般被用于异常处理快中,异常处理时提供 finally
块来执行任何清除操作。如果抛出一个异常,那么相匹配的 catch
子句就会执行,然后控制就会进入 finally
块(如果有的话)。
finally
块只要出现,就一定会被执行,不管它是否出现了异常。
有两种特殊情况需要注意:
- 一般情况下,在
catch
块中使用return
会强制结束方法,但是在存在finally块的情况下,要先执行finally
块中的语句,然后再执行return
。 - 如果在异常处理语句中使用
System.exit(1)
来退出虚拟机,finally块中语句将不会被执行。 - 如果在
finally
块中使用了return
或者throw
语句,则会在finally
块中直接终止,不再执行catch
块中的语句,所以不推荐在finally
块中使用return
和throw
。
finalize
Java 允许使用finalize()
方法在垃圾收集器将对象从内存中清除出去之前做必要的清理工作。这个方法是由垃圾收集器在确定这个对象没有被引用时对这个对象调用的。它是在Object
类中定义的,因此所有的类都继承了它。子类覆盖finalize()
方法以整理系统资源或者执行其他清理工作。finalize()
方法是在垃圾收集器删除对象之前对这个对象调用的。 当垃圾回收器(garbage colector
)决定回收某对象时,就会运行该对象的finalize()
方法。
总结
- final:是用来修饰类、方法、变量的。修饰类的,该类不能被修改继承。修饰变量时,变量必须被显式初始化,在初始化块中或者构造器或者声明时赋值。修饰方法时,该方法不能被重写,但是能够被重载。
- finally:是在异常处理中使用,在catch语句中不使用
System.exit(1)
时,一定会被执行。 - finalize:在对象被回收前使用执行清理工作。
网友评论