Java中调用父类构造器

首先子类不会获得超类的构造器,所以不会出现子类构造器重写超类构造器的情况。

但是子类构造器可以调用父类构造器的初始化代码,类似于一个类中,构造函数的重载。在一个构造器中调用另一个重载的构造器使用this来完成,在子类中调用父类的构造器使用super关键字来完成。

使用super调用和使用this调用很像,区别在于super调用的是父类的构造器,而this调用的是同一个类中重载的构造器。因此,使用super关键字调用父类的构造器时必须出现在子类构造器的第一行,所以,this和super调用不会同时出现。

不管是否使用super关键字调用父类的构造器的初始化代码,子类构造器总是会调用父类构造器一次,子类构造器调用父类构造器分为以下几个情况:

  1. 子类构造器执行的第一行使用了super显式调用父类构造器,系统会根据super调用里传入的实参列表调用父亲对应的构造器。
  2. 子类构造器执行体的第一行代码使用this显式调用本类中的重载的构造器,系统将根据this调用里传入的实参列表调用本类中的另一个构造器,执行本类的另一个构造器时即会调用父类构造器。
  3. 子类构造器执行体中没有super调用,也没有this调用,系统将会在执行子类构造器之前,隐式的调用父类构造器。

不管以上那种情况,当调用子类构造器来初始化子类对象时,父类构造器总会在子类构造器之前执行,不仅如此,执行父类构造器时,系统会再次向上溯其父类的构造器,一次类推,任何创建Java对象,都是最先执行java.lang.Object类的构造器。

public class Creature {
	public Creature(){
		System.out.println("Creature无参的构造器");
	}
}
class Animal extends Creature{
	public Animal(String name) {
		System.out.println("Animal 带一个参数的构造器,"+name);
	}
	public Animal(String name,int age) {
		this(name);
		System.out.println("Animal 带有两个参数的构造器"+age);
	}
}

public class Wolf extends Animal{
	public Wolf() {
		super("孙武",22);
		System.out.println("Wolf无参数的构造器");
	}
	public static void main(String[] args) {
		new Wolf();
	}
}

结果:
Creature无参的构造器
Animal 带一个参数的构造器,孙武
Animal 带有两个参数的构造器22
Wolf无参数的构造器

从上面的程序来看,创建任何对象都是从该类继承树最顶层类的构造器开始执行,然后依次向下执行,最后才执行本类构造器,如果父类通过this关键字调用同类的重载的构造器,就会依次执行此父类的多个构造器。

 

猜你喜欢

转载自blog.csdn.net/IBLiplus/article/details/81192986
今日推荐