五、Java继承(1)

1 继承

1.1 继承概述

继承概述:
	把多个类中相同的内容给提取出来定义到一个类中。
	
如何实现继承呢?	
	Java提供了关键字:extends	
格式:
	public class 子类名 extends 父类名 {}
	
Java中继承的特点
		A:Java中类只支持单继承
		B:Java中可以多层()继承(继承体系)

好处:
	A:提高了代码的复用性
	B:提高了代码的维护性
	C:让类与类之间产生了关系,是多态的前提

坏处:
	类与类产生了关系,其实也是继承的一个弊端:
	类的耦合性增强了。
	
	开发的原则:低耦合,高内聚。
	耦合:类与类的关系
	内聚:就是自己完成某件事情的能力

1.2 继承的注意事项

继承的注意事项:
	A:子类只能继承父类所有非私有的成员(成员方法和成员变量)
	B:子类不能继承父类的构造方法,但是可以通过super(马上讲)关键字去访问父类构造方法。
	C:不要为了部分功能而去继承
		class A {
			public void show1(){}
			public void show2(){}
		}
		
		class B {
			public void show2(){}
			public void show3(){}
		}
		
		//我们发现B类中出现了和A类一样的show2()方法,所以,我们就用继承来体现
		class B extends A {
			public void show3(){}
		}
		这样其实不好,因为这样你不但有了show2(),还多了show1()。
		有可能show1()不是你想要的。
		
那么,我们什么时候考虑使用继承呢?
	继承其实体现的是一种关系:"is a"。
		Person
			Student
			Teacher
		水果
			苹果
			香蕉
			橘子
			
	采用假设法。
		如果有两个类A,B。只有他们符合A是B的一种,或者B是A的一种,就可以考虑使用继承。

1.3 this和super的区别

this和super的区别?
分别是什么呢?
	this代表本类对应的引用。
	super代表父类存储空间的标识(可以理解为父类引用,可以操作父类的成员)

怎么用呢?
	A:调用成员变量
		this.成员变量 调用本类的成员变量
		super.成员变量 调用父类的成员变量
	B:调用构造方法
		this(...)	调用本类的构造方法
		super(...)	调用父类的构造方法
	C:调用成员方法
		this.成员方法 调用本类的成员方法
		super.成员方法 调用父类的成员方法
	D:this(...)或者super(...)必须出现在第一条语句上。
		否则报错,无法通过编译。
		如果不是放在第一条语句上,就可能对父类的数据进行了多次初始化,所以必须放在第一条语句上。

1.4 Java继承中的成员关系

A:成员变量
	a:子类的成员变量名称和父类中的成员变量名称不一样,这个太简单
	b:子类的成员变量名称和父类中的成员变量名称一样,这个怎么访问呢?
		子类的方法访问变量的查找顺序:
			在子类方法的局部范围找,有就使用。
			在子类的成员范围找,有就使用。
			在父类的成员范围找,有就使用。
			找不到,就报错。
			
			
B:构造方法
	a:子类的构造方法默认会去访问父类的无参构造方法
		是为了子类访问父类数据的初始化
	b:父类中如果没有无参构造方法,会怎么样?怎么办?
		父类无无参构造,子类调用会报错,无法通过编译。
		子类通过super去明确调用带参构造
		子类通过this调用本身的其他构造,但是一定会有一个去访问了父类的构造
		让父类提供无参构造


C:成员方法
	a:子类的成员方法和父类中的成员方法名称不一样,这个太简单
	b:子类的成员方法和父类中的成员方法名称一样,这个怎么访问呢?
		通过子类对象访问一个方法的查找顺序:
			在子类中找,有就使用
			在父类中找,有就使用
			找不到,就报错

1.5 override(重写)

  1. 方法重写:子类中出现了和父类中方法声明一模一样的方法。
  2. 方法重写的应用:
    当子类需要父类的功能,而功能主体子类有自己特有内容时,可以重写父类中的方法。这样,即沿袭了父类的功能,又定义了子类特有的内容。
3. 方法重写的注意事项
	A:父类中私有方法不能被重写
		因为父类私有方法子类根本就无法继承
		子类无法继承父类的私有成员(成员变量和成员方法)
	B:子类重写父类方法时,访问权限不能更低
		最好就一致
	C:父类静态方法,子类也必须通过静态方法进行重写
		其实这个算不上方法重写,但是现象确实如此,至于为什么算不上方法重写,多态中我会讲解
		
	子类重写父类方法的时候,最好声明一模一样。

1.6 数据初始化问题(面试)

案例1:

A:一个类的静态代码块,构造代码块,构造方法的执行流程
	静态代码块 > 构造代码块 > 构造方法
B:静态的内容是随着类的加载而加载
	静态代码块的内容会优先执行
C:子类初始化之前先会进行父类的初始化

分析:
1.类加载Zi z:Zi继承与Fu,先加载Fu的class再加载Zi的class,Fu的静态代码块首先被加载
2.加载完成之后:进行构造 new Zi(),先构造Fu,再构造Zi
/*
	结果是:
		静态代码块Fu
		静态代码块Zi
		构造代码块Fu
		构造方法Fu
		构造代码块Zi
		构造方法Zi
*/
class Fu {
	static {
		System.out.println("静态代码块Fu");
	}

	{
		System.out.println("构造代码块Fu");
	}

	public Fu() {
		System.out.println("构造方法Fu");
	}
}

class Zi extends Fu {
	static {
		System.out.println("静态代码块Zi");
	}

	{
		System.out.println("构造代码块Zi");
	}

	public Zi() {
		System.out.println("构造方法Zi");
	}
}

class ExtendsTest2 {
	public static void main(String[] args) {
		Zi z = new Zi();
	}
}

案例2:
分层初始化

/*
	看程序写结果:
		A:成员变量的问题
			int x = 10; //成员变量是基本类型
			Student s = new Student(); //成员变量是引用类型
		B:一个类的初始化过程
			成员变量的初始化
				默认初始化
				显示初始化
				构造方法初始化
		C:子父类的初始化(分层初始化)
			先进行父类初始化,然后进行子类初始化。
			
	结果:
		YXYZ
		
	问题:
		虽然子类中构造方法默认有一个super()
		初始化的时候,不是按照那个顺序进行的。
		而是按照分层初始化进行的。先父类,后子类,从成员到构造初始化
		它仅仅表示要先初始化父类数据,再初始化子类数据。
*/
class X {
	Y b = new Y();
	X() {
		System.out.print("X");
	}
}

class Y {
	Y() {
		System.out.print("Y");
	}
}

public class Z extends X {
	Y y = new Y();
	Z() {
		//super
		System.out.print("Z");
	}
	public static void main(String[] args) {
		new Z(); 
	}
}

1.7 两个面试题

两个面试题:
		A:Override和Overload的区别?Overload是否可以改变返回值类型?
		B:this和super的区别和各自的作用?
1:方法重写和方法重载的区别?方法重载能改变返回值类型吗?

方法重写:
	在子类中,出现和父类中一模一样的方法声明的现象。
	
方法重载:
	同一个类中,出现的方法名相同,参数列表不同的现象。


方法重载能改变返回值类型,因为它和返回值类型无关。


Override:方法重写
Overload:方法重载

2:this关键字和super关键字分别代表什么?以及他们各自的使用场景和作用。

this:代表当前类的对象引用
super:代表父类存储空间的标识。(可以理解为父类的引用,通过这个东西可以访问父类的成员)

场景:
	成员变量:
		this.成员变量
		super.成员变量
	构造方法:
		this(...)
		super(...)
	成员方法:
		this.成员方法
		super.成员方法

2 final关键字

2.1 final关键字特点

(1)是最终的意思,可以修饰类,方法,变量。
(2)特点:
	A:它修饰的类,不能被继承。
	B:它修饰的方法,不能被重写。
	C:它修饰的变量,是一个常量。

2.2 final修饰局部变量的问题

  1. 基本类型:基本类型的值不能发生改变。
  2. 引用类型:引用类型的地址值不能发生改变,但是,该对象的堆内存的值是可以改变的。

2.3 final修饰变量的初始化时机

  1. 只能初始化一次。
  2. 在构造方法完毕前。(非静态的常量),通常在定义的时候初始化

2.4 final修饰方法

由于继承中方法有一个现象:方法重写。
	所以,父类的功能,就会被子类给覆盖调。
	有些时候,我们不想让子类去覆盖掉父类的功能,只能让他使用。
	这个时候,针对这种情况,Java就提供了一个关键字:final
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值