Java继承树追溯

版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/qq_40301026/article/details/82852130

继承树追溯

属性/方法查找顺序:(比如:查找变量h)

1.查找当前类中有没有属性h

2.依次上溯每个父类,查看每个父类中是否有h,直EeJObject到

3.如果没找到,则出现编译错误。

4.上面步骤,只要找到h变量,则这个过程终止。

构造方法调用顺序:

构造方法第一句总是: super()来调用父类对应的构造方法。所以,流程就是:先向上追溯到 Object,然后再依次向下执行类的初始化块和构造方法,直到当前子类为止。

注:静态初始化块调用顺序,与构造方法调用顺序一样,不再重复。

package MyPro04_05;

public class TestSuper {
	public static void main(String[] args)
	{
		System.out.println("开始创建一个ChildClass对象.....");
		new ChildClass();
	}
}

class FatherClass
{
	public FatherClass()
	{
		super();  //编译时编译器会自动加,可以不写
		System.out.println("创建FatherClass");
	}
}

class ChildClass extends FatherClass
{
	public ChildClass()
	{
		super();    //编译时编译器会自动加,可以不写
		System.out.println("创建ChildClass");
	}
}

子类构造器会向上追溯其父类:

在内存中为:

猜你喜欢

转载自blog.csdn.net/qq_40301026/article/details/82852130