标签:不可 并发 ref ring strong main arch 显示 str
public class Father{
private int i = test();
private static int j = method();
static{
System.out.print("(1)");
}
Father(){
System.out.print("(2)");
}
{
System.out.print("(3)");
}
public int test(){
System.out.print("(4)");
return 1;
}
public static int method(){
System.out.print("(5)");
return 1;
}
}
public class Son extends Father{
//非静态实例变量显式赋值代码
private int i = test();
//类变量显式赋值代码
private static int j = method();
//静态代码块
static{
System.out.print("(6)");
}
Son(){
// super();//写或不写都在,在子类构造器中一定会调用父类的构造器
System.out.print("(7)");
}
//非静态代码块代码
{
System.out.print("(8)");
}
public int test(){
System.out.print("(9)");
return 1;
}
public static int method(){
System.out.print("(10)");
return 1;
}
public static void main(String[] args) {
//创建对象s1
Son s1 = new Son();
System.out.println();
//创建对象s2
Son s2 = new Son();
}
}
(5)(1)(10)(6)(9)(3)(2)(9)(8)(7)
(9)(3)(2)(9)(8)(7)
创建过程解读:
类初始化
一个类要创建实例需要先加载并初始化该类
main方法所在的类需要先加载和初始化
一个子类要初始化需要先初始化父类
一个类初始化就是执行
类变量显式赋值代码和静态代码块代码从上到下顺序执行
实例初始化
实例初始化就是执行
非静态实例变量显示赋值代码和非静态代码块代码从上到下顺序执行,而对应构造器的代码最后执行
每次创建实例对象,调用对应构造器,执行的就是对应的
方法的重写:final方法、静态方法、private等子类中不可见方法不可以被重写。
对象的多态性:子类如果重写了父类的方法,通过子类对象调用的一定是子类重写过的代码;非静态方法默认的调用对象是this,this对象在构造器或者说
复习创建对象的步骤
详情见:创建对象发生的那些事儿
原创不易,欢迎转载,转载时请注明出处,谢谢!
作者:潇~萧下
原文链接:https://www.cnblogs.com/manongxiao/p/14503143.html
标签:不可 并发 ref ring strong main arch 显示 str
原文地址:https://www.cnblogs.com/manongxiao/p/14503143.html