5.1 用构造器确保初始化
Java中构造器采用与类名相同的名字,首字母必须大写。不接受任何参数的构造器叫做无参构造器,也有有参构造器,可以在初始化对象的时候提供一些参数。
构造器没有返回值。这与返回值为空(void)有明显不同。对于空返回值,尽管方法本身不会自动返回什么,但是仍可以选择让它返回一些东西。构造器则不会返回任何东西,别无选择。
Java中,初始化和创建时捆绑在一起的,两者不能分离。
5.2 方法重载
5.2.1 区分重载方法
每个重载方法都必须要有一个独一无二的参数类型列表。包括参数数量、类型、顺序等。
5.2.2 涉及基本类型的重载
如果某这个基本类型的重载,使用这个。
如果传入的数据类型小于方法中声明的形式参数类型,实际数据类型就会被提升。char类型特殊,若找不到,会提升至int型。
如果传入的数据类型大于方法中声明的形式参数类型,必须通过类型转换的窄化转换,即显式转换,否则编译器会报错。
无法通过返回值来区分重载方法。
5.3 默认构造器
如果你写的类中没有构造器,则编译器会自动帮你创建一个默认构造器(无参构造器),如果已经定义了一个构造器,不管是有参的还是无参的,编译器就不会再创建一个了。
5.4 this关键字
假设希望在方法的内部获得对当前对象的引用,可以用this关键字。
只有当需要明确得指出对当前对象的引用时,才需要使用this。如果在方法内部调用同一个类的另一个方法,就不必使用this,直接调用即可。
5.4.1 在构造器中调用构造器
如果想要在一个构造器中调用另一个构造器,以避免重复代码,可以使用this.
可以用this调用一个构造器,不能够调用两次。
必须将构造器调用置于最起始处。并且只能在构造器中调用。
5.4.2 static的含义
static方法就是没有this的方法,在static方法的内部就不能调用非静态方法。
static方法最主要的用途:直接用类名调用。
class Person{
static A(int i){
C(i);
//静态方法A,这里调用同一个类下的C方法,C是一个普通方法,编译器报错。因为C()等价于this.C(),而this不存在。 }
void B(int i){
C(i);
//这里可以这么写,因为C()等价于this.C()。而普通方法在创建对象时生成,this表示调用B()的对象,故调用成功。 }
void C(int i){}
}
5.5 清理:终结处理和垃圾回收
假定一个对象并非使用new获得了一块特殊的内存区域,由于垃圾回收器只知道释放那些经由new分配的内存,所以它不知道该如何释放这一块特殊的内存。
为了应付这种情况,Java允许在类中定义一个名为finalize()的方法。它的工作原理假定是这样的:一旦垃圾回收器准备好释放对象占用的存储空间,将首先调用其finalize()方法,并且在下次回收动作发生时,才真正回收对象占用的内存。
Java的finalize()和C++析构函数不同,析构函数在调用完成后会自动调用解放对象占用的内存。Java对象并非总是被垃圾回收的。
5.5.1 finalize()的用途何在
对象可能不被垃圾回收;垃圾回收不等于析构;垃圾回收只与内存有关。
使用垃圾回收器的唯一原因是为了回收程序不再使用的内存。
finalize()的用途就是在使用“本地方法”的情况下,本地方法是一种在java中调用非java代码的方式,一般来讲是c和C++,如C的malloc()函数分配储存空间,只能free()函数来释放空间,这需要将free()函数在finalize()中调用。
finalize 方法将在垃圾回收器清除对象之前调用。在实际应用中,不要依赖于使用 finalize 方法回收任何短缺的资源, 这是因为很难知道这个方法什么时候才能够调用。
5.5.2 你必须实施清理
Java不允许创建局部对象,必须使用new创建对象。在Java中也没有用于释放对象的delete,因为垃圾回收器会帮助你释放存储空间。甚至可以认为,正是因为有垃圾收集的机制,所以Java没有析构函数。而且不能随便的调用finalize。
5.5.3 终结条件
System.gc()用于强制进行终结动作。
5.5.4 垃圾回收器如何工作的
http://www.cnblogs.com/andy-zcx/p/5522836.html
5.6 成员初始化
在Java中,面对局部变量没有被初始化时会得到编译错误的消息。这是因为可能程序猿因为粗心忘记了初始化,如果使用默认值就掩盖了这种错误。
而对于类的数据成员,Java保证每一个基本类型成员都有初始化值,如果是一个引用类型,就会得到null。
5.7 构造器初始化
可以使用构造器来进行初始化。但是无法阻止自动初始化的进行,它将在构造器被调用之前发生。
举个例子
class Counter{
int i;
Counter(){i=7;}
}
这里变量i会先初始化为0,然后在调用构造器后,变成7.
5.7.1 初始化顺序
在类的内部,变量定义的先后顺序决定了初始化的顺序,假如变量分布在各处,也是按照从上向下的顺序初始化。
5.7.2 静态数据的初始化
无论创建多少个对象,静态数据只占用一份储存区域。static 关键字不能应用于局部变量,即只能作为类的数据成员。
5.8 数组初始化
Arrays.toString()方法属于java.util标准类库,将产生一维数组的可打印版本。
5.9 枚举类型
枚举类型是Java 5中新增特性的一部分,它是一种特殊的数据类型,之所以特殊是因为它既是一种类(class)类型却又比类类型多了些特殊的约束,但是这些约束的存在也造就了枚举类型的简洁性、安全性以及便捷性。
public class EnumDemo {
public static void main(String[] args){
//直接引用 Day day =Day.MONDAY;
}
}//定义枚举类型enum Day {
MONDAY, TUESDAY, WEDNESDAY,
THURSDAY, FRIDAY, SATURDAY, SUNDAY
}
实际上在使用关键字enum创建枚举类型并编译后,编译器会为我们生成一个相关的类,这个类继承了Java API中的java.lang.Enum类,也就是说通过关键字enum创建枚举类型在编译后事实上也是一个类类型而且该类继承自java.lang.Enum类。
编译器确实帮助我们生成了一个Day类(注意该类是final类型的,将无法被继承)而且该类继承自java.lang.Enum类,该类是一个抽象类(稍后我们会分析该类中的主要方法),除此之外,编译器还帮助我们生成了7个Day类型的实例对象分别对应枚举中定义的7个日期,这也充分说明了我们前面使用关键字enum定义的Day类型中的每种日期枚举常量也是实实在在的Day实例对象,只不过代表的内容不一样而已。注意编译器还为我们生成了两个静态方法,分别是values()和 valueOf()。