final finalize finally

final:

final(不能被继承)与abstract(只能被继承)永远不能同时修饰类。

修饰类,变量,方法。

修饰变量:成员变量(类变量,实例变量),局部变量,形参。
类变量:随类初始化而初始化的。静态初始化时,声明变量时初始化。
实例变量:随对象初始化而初始化的。普通初始化块,静态代码块。
实例变量不能在静态代码块中指定初始值。
类变量不能在普通代码块中指定初始值。
final成员变量必须由程序员显示初始化,系统不会对final变量进行隐式初始化。
局部变量:定义时可指定默认值;若不指定,则在之后进行赋值,只能一次。
形参变量:不能被赋值。

修饰基本数据类型和引用类型:
基本数据类型:基本数据不能被修改。
引用类型:引用类型变量所引用的地址不会改变,即一直引用同一个对象,但是这个对象可改变。

修饰方法:不可被重写。若不希望子类重写父类某个方法,则用final修饰。
final修饰private访问权限的方法,可在子类中定义与该方法同名、同参、同返回类型的方法。
final修饰的方法不能被重写,但可重载。

修饰类:修饰的类不可以有子类。例如java.lang.Math。

不可变类:创建该类实例后,实例的变量不可改变。例如Java的8个包装类。
可变类:该类实例变量可变。

不可变类遵守的规则:
1、使用private,final修饰变量。
2、提供带参构造器,用于传参初始化类里的变量。
3、只提供get方法,不提供set方法。
4、按须重写Objec类的hashCode,equals方法。

finalize

垃圾回收机制的特征:
1、只负责回收堆内存,不会回收物理内存(数据库连接,网络IO等)。
2、程序无法精确控制垃圾回收的运行,系统会在合适的时候进行回收。
3、垃圾回收机制在回收任何对象之前,总会先调用finalize()方法。该方法可让对象重新复活。

对象在内存中的状态:可达状态,可恢复状态,不可达状态。

强制垃圾回收:
静态方法:System.gc()。
实例方法:Runtime.getRuntime().gc()。

finalize()方法:
垃圾回收机制回收某个对象占用的内存之前,通常要求程序调用适当的方法来清理资源,在没有明确指定清理资源的情况下,Java提供默认机制来清理该对象的资源,即finalize方法。此方法是Object类里的实例方法。

finalize方法4个特点:
1、不要主动调用某个对象的此方法,交给垃圾回收机制。
2、此方法何时被调用不一定,不要把此方法当成一定会被执行的方法。
3、可恢复变可达。
4、finalize异常时,垃圾回收机制不会报错,程序继续执行。

public class demo2 {
private static demo2 d = null;

public void infor() {
    System.out.println("test finalise function");
}

public static void main(String args[]) {
    // 对象进行可恢复状态
    new demo2();
    // 通知系统进行资源回收
    System.gc();
    try {
        // 强制垃圾回收机制调用可恢复对象的finalize方法
        Runtime.getRuntime().runFinalization();
        // 让程序停止2s
        // Thread.sleep(200);

    } catch (Exception e) {
        e.printStackTrace();
    }
    d.infor();
}

public void finalize() {
    d = this;
}

}

finally:
1、回收资源
2、方法执行return退出程序之前,执行finally方法体
3、若异常处理代码中执行Syste.exit()退出虚拟机,则finally方法体不被执行。
throws抛出异常:
当前方法不知道如何处理这种异常,该异常应该由上一级调用者处理。
如果不main方法也不知道如何处理,也可用throws声明抛出异常,该异常交给JVM处理。
JVM处理方法:打印异常跟踪栈信息,并路上程序运行。
throws声明抛出异常时限制:
方法重写时“两小”中的一条规:子类方法声明抛出的异常类型应是父类方法声明抛出的异常类型的子类或相同。
子类方法声明抛出的异常不允许比父类方法声明抛出的异常多。

你可能感兴趣的:(final finalize finally)