面向对象(子父类中构造函数的特点-子类实例化过程)

本文探讨了子类对象初始化过程中父类构造函数的作用及访问机制。子类构造函数默认包含super()语句以调用父类无参构造函数,确保父类数据正确初始化。当父类无默认构造函数时,子类需显式调用super或其他方式指定父类构造函数。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

/*
3、子父类中的构造函数。

在对子类对象进行初始化时,父类的构造函数也会运行。
那是因为子类的构造函数默认第一行有一条隐式的语句 super();
super():会访问父类中空参数的构造函数。而且子类中所有的构造函数默认第一行都是super()。

为什么子类一定要访问父类中的构造函数。
因为父类中的数据子类可以直接获取,所以子类对象在建立时,需要先查看父类是如何对这些数据进行初始化的。
所以子类在对象初始化时,先访问一下父类中的构造函数。
如果要访问父类中指定的构造函数,可以通过手动定义super语句的方式来指定。

注意:super语句一定定义在子类构造函数的第一行。

子类的实例化过程

结论:
子类的所有的构造函数,默认都会访问父类中空参数的构造函数。
因为子类每一个构造函数内的第一行都有一句隐藏的super()

当父类中没有空参数的构造函数时,子类必须手动通过super或者this语句形式
来指定要访问父类中的构造函数。

当然:子类的构造函数第一行也可以手动指定this语句来访问本类中的
构造函数。子类中至少会有一个构造函数会访问父类中的构造函数。
*/
class Fu//extends Object
{

    int num;
    Fu()//构造函数,如果不定义,就默认为Fu(){}
    {
        //super();
        num=60;
        System.out.println("fu run");
    }
    //不会默认访问到下面的非空参数的构造函数。
    Fu(int x)
    {
        System.out.println("fu x..."+x);
    }
}
class Zi extends Fu
{
    Zi()//构造函数,如果不定义,就默认为Zi(){}
    {
        //super();//默认隐藏。会访问父类中空参数的构造函数。
        //super(4);//这样子就不会默认调用父类中空参数的构造函数了

        System.out.println("zi run");
    }
    Zi(int x)
    {
        //this();//若第一行写了这句,super()就不是第一行了。
        //super();//默认隐藏。会访问父类中空参数的构造函数。
        System.out.println("zi ..."+x);
    }
}

class ExtendsDemo4
{
    public static void main(String[] args)
    {
        Zi z=new Zi();
        //Zi z1=new Zi(4);
        System.out.println(z.num);
    }
}

class Person
{
    String name;
    Person(String name)
    {
        this.name=name;
    }

    void show()
    {
        System.out.println("name="+name);
    }
}

class Student extends Person
{
    Student(String name)
    {
        super(name);//调用父类的东西,不用从新定义
    }
    void method()
    {
        super.show();//调用父类的方法。
    }
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值