java多态之父子构造器

下面这种情况大家知道编译器会报错
package com.unis.object;

public class Parent {
	
	private String name;
	 
	public Parent(String name) {
		this.name = name;
	}
}

class Child extends Parent{
	
}

解决办法,大家都知道在Parent这个类中提供一个无参的构造器(即默认构造器)。
public Parent() {
		
}

或是在Child这个类中提供下面这样的一个构造器,都可以使编译器消除错误:
	public Child() {
		super("skyuck");
	}


解决方法都知道,可是为什么要这样解决呢
在Child这个类中其实java编译器会尝试加一个默认的构造器。但是这样加就会有一个问题,就是java在分配内存空间是会先分配父类的内存,然后再为子类分配内存。但是这个时候父类占用多少内存空间都没有确定,因此编译器就会提示错误,因此我们必须在子类必须为父类的内存空间给分配好(调用父类的构造方法)或者直接在父类提供一个默认的空构造器便个解决。

我们可以把上面的代码改成这种形式
package com.unis.object;

public class Parent {
	
	private String name;
	
	public Parent() {
		System.out.println("父类的默认构造器");
	}
	
	 
	public Parent(String name) {
		System.out.println("父类带参数的构造器");
		this.name = name;
	}
	
	public static void main(String[] args) {
		Child c = new Child();
	}
}

class Child extends Parent{
	
//	public Child() {
//		super("skyuck");
//	}
	
}


运行一下我们会发现输出的内容为:
引用

父类的默认构造器

因为这个时候要通过父类提供的无参构造器为parent分配空间。

这个时候我们把Child类中的注释去掉,运行结果为:
引用

父类带参数的构造器

这个时候就会通过super("skyuck")调用父类带参数的构造器为name属性分配内存空间。

由于作者水平有限,表述不清或有错误的地方还请大家斧正。

你可能感兴趣的:(java)