下面这种情况大家知道编译器会报错
解决办法,大家都知道在Parent这个类中提供一个无参的构造器(即默认构造器)。
或是在Child这个类中提供下面这样的一个构造器,都可以使编译器消除错误:
解决方法都知道,可是为什么要这样解决呢
在Child这个类中其实java编译器会尝试加一个默认的构造器。但是这样加就会有一个问题,就是java在分配内存空间是会先分配父类的内存,然后再为子类分配内存。但是这个时候父类占用多少内存空间都没有确定,因此编译器就会提示错误,因此我们必须在子类必须为父类的内存空间给分配好(调用父类的构造方法)或者直接在父类提供一个默认的空构造器便个解决。
我们可以把上面的代码改成这种形式
运行一下我们会发现输出的内容为:
[quote]
父类的默认构造器
[/quote]
因为这个时候要通过父类提供的无参构造器为parent分配空间。
这个时候我们把Child类中的注释去掉,运行结果为:
[quote]
父类带参数的构造器
[/quote]
这个时候就会通过super("skyuck")调用父类带参数的构造器为name属性分配内存空间。
由于作者水平有限,表述不清或有错误的地方还请大家斧正。
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属性分配内存空间。
由于作者水平有限,表述不清或有错误的地方还请大家斧正。