继承——子父类出现后,类成员的特点

本文详细解析了子父类中的成员变量、函数和构造函数的特点。子类如何通过this和super关键字访问自身及父类的同名成员变量;函数重写时权限控制的要求;构造函数如何确保正确调用父类构造函数。

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

子父类出现后,类成员的特点

类中成员:
1.变量  如果子类中出现非私有的同名成员变量时,
子类要访问本类中的变量,用this,
子类要访问父类中的同名变量,用super

super的使用和this的使用几乎一致
this代表的是本类对象的引用,super代表的是父类对象的引用


2.函数  当子类出现和父类一模一样的函数时,当子类对象调用该函数,会运行子类函数的内容,
如同父类的函数被覆盖一样
这种情况是函数的另一个特性:重写(覆盖)

当子类继承父类,延袭了父类的功能到子类中,但是子类虽具备该功能,但是功能的内容却和父类
不一致,这时,没必要定义新功能,而是使用覆盖特性,保留父类的功能定义,而重写功能内容

覆盖:
1>子类覆盖父类,必须保证子类权限大于等于父类权限,才可以覆盖,否则编译失败
2>静态只能覆盖静态

重载只看同名函数的参数列表,重写:子父类方法要一模一样(包括返回类型)


3.构造函数  在对子类对象进行初始化时,父类的构造函数也会运行,那是因为子类的构造函数默认第一行有一条
隐式的语句 super();

super():会访问父类中空参数的构造函数,而且子类中所有的构造函数默认第一行都是super();

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

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

结论(子类的实例化过程):
子类的所有的构造函数,默认都会访问父类中空参数的构造函数
因为子类每一个构造函数内的第一行都有一句隐式super();
当父类中没有空参数的构造函数时,子类必须手动通过super语句的形式来指定要访问的父类中的构造函数
当然子类的构造函数第一行也可以手动指定this语句来访问本类中的构造函数,子类中至少会有一个构造函数
会访问父类中的构造函数

class Fu{
	Fu(){
		System.out.println("fu run");
	}
}

class Zi extends Fu{
	Zi(){
		//super(); 默认有
		System.out.println("zi run");
	}
}

class Demo{
	public static void main(String[] args){
		Zi z = new Zi();
		//运行打印  先fu run  后zi run
	}
}

class Fu{
	Fu(int x){
		System.out.println("fu run");
	}
}

class Zi extends Fu{
	Zi(){
		super(4); //此时要手动指定
		System.out.println("zi run");
	}
}




评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值