final, finally, finalize 的区别
- final是一个关键字,可以修饰类、变量(类变量和成员变量)、方法。final变量初始化赋值之后,不允许再被赋值(引用类型的变量,则在对其初始化之后便不能再让其指向另一个对象),若试图修改,编译器会报错;final类不允许被继承,final类中的所有成员方法会被隐式指定为final方法;final方法不允许被重载。
特别注意
1)final修饰的引用变量指向的对象内容可以改变。
2)当final变量是基本数据类型以及String类型时,如果在编译期间能知道它的确切值,则编译器会把它当做编译期常量使用,不需要在运行时期确定。final方法在编译阶段绑定,称为静态绑定(static binding)。
3)匿名内部类中使用的外部局部变量只能是final变量。
4)final成员变量必须在声明的时候初始化或者在构造器中初始化,否则就会报编译错误;本地变量必须在声明时赋值。
5)接口中声明的所有变量本身是final的。
6)final变量可以安全的在多线程环境下进行共享,而不需要额外的同步开销。
finally也是一个关键字,主要用于资源回收。当代码抛出异常,该方法中剩余的代码就不会被执行,会产生资源回收问题,利用finally块来关闭已打开的资源。
finalize是一个方法。在垃圾回收器回收分配给对象的存储空间之前调用,特别注意,虽然子类可以覆盖 finalize() 方法以整理系统资源或者执行其他清理工作,但因为很难知道finalize方法什么时候会被调用,所以不要依靠finalize方法进行资源回收
包装类
自动将基本类型转为引用类型的过程称为装箱,装箱的实质是调用包装器的valueOf方法实现;自动将引用类型转为基本类型的过程为拆箱,拆箱的实质是调用包装器的xxxValue方法(xxx代表对应的基本数据类型)实现。
装箱 Integer num = Integer.valueOf(3);
拆箱 int num = new Integer(3).intValue();
特别注意:
- 装箱和拆箱发生在编译时期。
- 自动装箱规范要求boolean、byte、char 127,介于-128~127之间的short和 int被包装到固定的对象中,否则创建一个新对象。
- 对于自增操作,要先拆箱,再计算,最后装箱。
Integer n = 3;
n++;
重载(overload)与重写(override)
将方法名和参数列表称为方法签名
override(重写):方法签名相同,返回值相同
- 方法名、参数、返回值相同。
- 子类方法不能缩小父类方法的访问权限。
- 子类方法不能抛出比父类方法更多的异常(但子类方法可以不抛出异常)。
- 存在于父类和子类之间。
- 方法被定义为final不能被重写。
overload(重载):方法名相同,参数不同
- 参数类型、个数、顺序至少有一个不相同。
- 不能重载只有返回值不同的方法名。
- 存在于父类和子类、同类中。
注:重载解析:编译器根据各个方法给出的参数类型与特定方法调用所使用的值类型进行匹配来挑选出相应的方法