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");
// }

}


运行一下我们会发现输出的内容为:
[quote]
父类的默认构造器
[/quote]
因为这个时候要通过父类提供的无参构造器为parent分配空间。

这个时候我们把Child类中的注释去掉,运行结果为:
[quote]
父类带参数的构造器
[/quote]
这个时候就会通过super("skyuck")调用父类带参数的构造器为name属性分配内存空间。

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

你可能感兴趣的:(java,core)