Java面向对象 继承
知识概要:
(1)继承的概述
(2)继承的特点
(3)super关键字
(4)函数覆盖
(5) 子类的实例化过程
(6) final关键字
(1)继承的概述
多个类中存在相同属性和行为时,将这些内容抽取到单独一个类中,那么多个类无需再定义这些属性和行
为,只要继承单独的那个类即可。 多个类可以称为子类,单独这个类称为父类或者超类。
子类可以直接访问父类中的非私有的属性和行为。通过extends 关键字让类与类之间产生继承关系。
• class SubDemo extends Demo{}
继承的出现提高了代码的复用性。
继承的出现让类与类之间产生了关系,提供了多态的前提。
(2)继承的特点
Java只支持单继承,不支持多继承。
• 一个类只能有一个父类,不可以有多个父类。
• class SubDemo extends Demo{} //ok
• class SubDemo extends Demo1,Demo2...//error
Java支持多层继承(继承体系)
• class A{}
• class B extends A{}
• class C extends B{}
学习总结:
如何使用一个继承体系中的功能呢?
想要使用体系,先查阅体系父类的描述,因为父类中定义的是该体系*性功能。
通过了解共性功能,就可以知道该体系的基本功能。
那么这个体系已经可以基本使用了。
那么在具体调用时,要创建最子类的对象,为什么呢?
一是因为有可能父类不能创建对象,
二是创建子类对象可以使用更多的功能,包括基本的也包括特有的。
简单一句话:查阅父类功能,创建子类对象使用功能。
定义继承需要注意:
• 不要仅为了获取其他类中某个功能而去继承
• 类与类之间要有所属( " is a " )关系,xx1是xx2的一种。
• 千万不要为了获取其他类的功能,简化代码而继承。
(3) super关键字
super和this的用法相同
this代表本类应用
super代表父类引用
当子父类出现同名成员时,可以用super进行区分
子类要调用父类构造函数时,可以使用super语句。
子类要访问本类中的变量,用this
子类要访问父类中的同名变量,用super。
super的使用和this的使用几乎一致。
this代表的是本类对象的引用。
super代表的是父类对象的引用。
(4)函数覆盖(Override)
函数覆盖和重载的区别?
观察函数的覆盖时要求函数名相同,参数列表相同。函数重载时,是指本类中同名函数参数不同(个数,顺
序)即构成重载。
子类中出现与父类一模一样的方法时,会出现覆盖操作,也称为重写或者复写。
父类中的私有方法不可以被覆盖。
在子类覆盖方法中,继续使用被覆盖的方法可以通过super.函数名 获取。
覆盖注意事项:
• 覆盖时,子类方法权限一定要大于等于父类方法权限
• 静态只能覆盖静态。
覆盖的应用:
• 当子类需要父类的功能,而功能主体子类有自己特有内容时,可以复写父类中的方法,这样,即沿袭了父类的
功能,又定义了子类特有的内容。
(5)子类的实例化过程
子父类中的构造函数。
在对子类对象进行初始化时,父类的构造函数也会运行,那是因为子类的构造函数默认第一行有一条隐式的语
句super()
注意:super语句一定定义在子类构造函数的第一行。
子类的实例化过程。
当然:子类的构造函数第一行也可以手动指定this语句来访问本类中的构造函数。
子类中至少会有一个构造函数会访问父类中的构造函数。
子类中所有的构造函数默认都会访问父类中空参数的构造函数
因为每一个构造函数的第一行都有一条默认的语句 super();
子类会具备父类中的数据,所以要先明确父类是如何 对这些数据初始化的。
当父类中没有空参数的构造函数时,子类的构造函数必须通过this或者super语句指定要访问的构造函数。
class Fu //extends Object
{
int num ;
Fu()
{
//super();
num= 60;
System.out.println("fu run");
}
Fu(int x)
{
System.out.println("fu ...."+x);
} } class Zi extends Fu
{
Zi()
{ //super();
super(4);
System.out.println("zi run");
}
Zi(int x)
{
this();
//super(3);
System.out.println("zi..."+x);
}
} class ExtendsDemo4
{
public static void main(String[] args)
{
Zi z = new Zi(0);
System.out.println(z.num);
}
}
(6) final关键字
final可以修饰类,方法,变量。
final修饰的类不可以被继承。
final修饰的方法不可以被覆盖。
final修饰的变量是一个常量。只能被赋值一次。
当在描述事物时,一些数据的出现值是固定的,那么这时为了增强阅读性,都给这些值起个名字。方便于阅
读而这个值不需要改变,所以加上final修饰。作为常量:常量的书写规范所有字母都大写,如果由多个单词组
成单词间通过_连接。 XXX_YYY_ZZZ
内部类只能访问被final修饰的局部变量。 (而后的博客中会仔细讲到)