黑马程序员—继承中构造函数的特点

本文详细介绍了子类实例化过程中如何通过super()访问父类构造函数,并解释了为何子类需要这样做。同时,文章提供了代码示例,展示了如何在不同情况下正确使用super()。

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

    子类的实例化过程:

1、子类的构造函数第一条:隐式的super();

      注意:当父类中没有空参数的构造函数时,要访问父类中指定的构造函数,

必须通过手动定义super();语句来指定要访问父类中哪个构造函数。

2、子类一定要访问父类中的构造函数的原因

      通过继承,父类中的数据子类可以直接获取,所以子类对象在建立时,需要先查看父类是如何对这些数据进行初始化的,所以要先访问父类中的构造函数。

    

    特点:

super();必须在构造函数的第一行

 class Fu
{
	int num;
	Fu()
	{
		num = 60;//子类需考虑父类在构造函数中对数据进行哪些操作
				 //所以子类要通过super();先访问父类中的构造函数
		System.out.println("fu run");
	}
}
class Zi extends Fu
{
	Zi()
	{
		//super();隐式
		//注意:当父类没有空参数的构造函数,
		//子类必须手动指定要访问哪个构造函数super(4);
		System.out.println("zi run");
	}
	Zi(int x)
	{
		//super();隐式
		System.out.println("zi run"+x);
	}
	
}
class ExtendsDemo
{
	public static void main(String[] args)
	{
		Zi z1 = new Zi();
		Zi z2 = new Zi(4);
	}
}


    结论:子类中所有的构造函数默认都会访问空参数中的构造函数
        因为子类每一个构造函数内的第一行都有一句隐式的super();或者自定义的super();语句
        当然,子类的构造函数也可以手动指定this语句来访问本类中的构造函数,但是子类中至少会有一个构造函 数会访问父类中的构造函数



评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值