再谈类的初始化
前面一篇文章“Java权限问题”的最后说到了类的初始化问题:
对象的初始化:
1)首先初始化类,即执行Static (包括Static成员变量,Static代码块,顺序与书写顺序相同),加载到内存。
2)然后初始化对象(包括非Static成员变量,构造代码块,顺序与书写顺序相同)
3)构造函数
4)最后其中还有静态方法和非静态方法,不存在初始化这个概念,使用即可。 在1)就已经加载到内存了。
如果有父类的话,步骤如下:
1)首先初始化父类,即执行Static (包括Static成员变量,Static代码块,顺序与书写顺序相同),然后子类,加载到内存。
2)然后初始化父类对象(包括非Static成员变量,构造代码块,顺序与书写顺序相同)
3)父类构造函数
4)然后初始化子类对象(包括非Static成员变量,构造代码块,顺序与书写顺序相同)
5)子类构造函数
6)最后其中还有静态方法和非静态方法,不存在初始化这个概念,使用即可。
对于类中的静态变量来说,其实在所有的程序代码执行(真正的初始化)之前,就会先默认初始化,比如int默认为0,然后才会按照上面所述的顺序继续初始化,如下面一个例子:
class SingleTon {
private static SingleTon singleTon = new SingleTon();
public static int count1;
public static int count2 = 0;
private SingleTon() {
count1++;
count2++;
}
public static SingleTon getInstance() {
return singleTon;
}
}
public class Test {
public static void main(String[] args) {
SingleTon singleTon = SingleTon.getInstance();
System.out.println("count1=" + singleTon.count1);
System.out.println("count2=" + singleTon.count2);
}
}
它会按照顺序,先初始化singleTon这个静态变量,然后就会执行构造方法,构造方法对count1和count2进行自增操作时,并不会报错,因为在真正的初始化之前,这两个变量已经声明了,而且默认初始化的值为0,然后执行完构造函数后,值都为1,最后在执行count1和count2的显示初始化,所以最终count1和count2的值为1,0