现在已经成功的实现了 继承的关系,并且也已经发现了继承主要特点,但是一旦程序之中提供有继承逻辑,那么对于子类对象的实例化定义是有要求。从正常的社会逻辑来讲:没有父母就没有你,对于继承程序的逻辑也是一样的,在进行子类对象实例化的时候,一定要默认实例化好父类对象。
范例:
class JavaDemo
{
public static void main(String[] args)
{
new Student();
}
}
class Person
{
public Person(){
System.out.println("【Person父类】一个新的Person父类实例化对象产生了");
}
}
class Student extends Person
{
public Student(){
System.out.println("【Student子类】一个新的Student实例化对象产生了");
}
}
现在即使没有父类对象实例化,也会由系统自动调用父类的构造方法(实例化父类对象),默认实例化子类流程中会自动实例化父类。实际上这个时候就相当于子类的构造方法里面隐含了一个“super()”的形式。
范例:
class JavaDemo
{
public static void main(String[] args)
{
new Student();
}
}
class Person
{
public Person(){
super();//写与不写此语句效果都一样
System.out.println("【Person父类】一个新的Person父类实例化对象产生了");
}
}
class Student extends Person
{
public Student(){
System.out.println("【Student子类】一个新的Student实例化对象产生了");
}
}
super()表示的就是子类构造调用父类构造的语句,该语句只允许放在子类构造方法的首行。在默认情况下的实例化处理子类只会调用父类无参构造方法,所以写与不写“super()”区别不大,但是如果说父类里面没有提供无参构造,这个时候必需利用“super()”明确调用有参构造。
class JavaDemo
{
public static void main(String[] args)
{
new Student("王五",48,"北京大学");//实例化子类对象
}
}
class Person
{
private String name;
private int age;
public Person(String name,int age){
this.name = name;
this.age = age;
}
}
class Student extends Person //Student是子类
{
private String school ;
public Student(String name,int age,String school){//构造方法
super(name,age);//明确调用父类构造
this.school = school;
}
}
结论:无论如何,在实例化子类对象的同时一定会实例化父类,目的是为了所有的属性可以进行空间的分配
super和this都可以调用构造方法,super()由子类调用父类的构造,而this是调用本类构造,并且都一定要放在构造方法的首行,所以两个语句不允许同时出现。