上章我们进行了面向对象的学习,
发现如果定义的几个类中的属性和方法重复,
代码是不是会显得很冗余啊?,有没有一种思想可以简化呢?
有!下面我们来看继承就能解决这个问题
1、继承-概述
继承:
1,提高了代码的复用性
2,让类与类之间产生了关系,也就是多态的特性
注意:千万不要为了获取其它类的功能,简化代码而继承
必须是类与类之间有所属关系才可以继承。
Java语言中:java只支持单继承,不支持多继承
因为多继承容易带来安全隐患:当多个父类中定义了相同功能
且功能内容不同时,子类对象不确定运行哪一个。
但是java保留这种机制,并用另一种体现形式来完成表示:多实现。
java支持多层继承,也就是一个继承体系
如何使用一个集成体系中的功能呢?
想要使用体系,先查阅体系父类的描述,因为父类中定义的是该体系中共性功能
通过了解共性功能,就可以知道该体系的基本功能
那么这个体系已经可以基本使用了
那么在具体调用时,要创建最子类的对象,为什么?
一是因为有可能父类不能创建对象,
二是创建子类对象可以使用更多的功能,包括基本的也包括特有的
简单一句话:查阅父类功能,创建子类对象使用功能
2、继承的特点
子父类出现后,类成员的特点:
类中成员:
1,变量。
2,函数。
3,构造函数。
1,变量
如果子类中出现非私有的同名成员变量是
子类要访问本类中的变量,用this
子类要访问父类中的同名变量,用super
2,函数
子类出现和父类一摸一样的函数时,
当子类对象调用该函数,会运行子类函数的内容。
这种情况是函数的另一个特性:重写(覆盖)
重写可以便于扩展
覆盖:
1,子类覆盖父类,必须保证子类权限大于等于父类权限,才可以覆盖,否则编译失败
2,静态覆盖静态
记住大家:
重载:只看同名函数的参数列表
重写:子父类方法要一模一样
3,子父类中构造函数
在对子类对象进行初始化时,父类的构造函数也会运行,
那是因为子类的构造函数默认第一行有一条隐式语句 super()
super():会访问父类中空参数的构造函数,而且子类中所有的构造函数默认第一行都是super();
super()指的是Fu(){}
为什么子类一定要访问父类中的构造函数
因为父类中的数据子类可以直接获取,所以子类对象在建立时,
需要先查看父类是如何对这些数据进行初始化的。
所以子类在对象初始化时,要先访问一下父类中的构造函数。
如果要访问父类中指定的构造函数,可以通过手动定义super语句的方式来指定
注意:super语句一定定义在子类构造函数的第一行,因为初始化动作要先做
构造函数里要么有this()要么有super(),只能其一。(Object是所有的类的父类)
结论:
子类的所有的构造函数,默认都会访问父类中空参数的构造函数。
因为子类每一个构造函数内的第一行都有一句隐式super();
当父类中没有空参数的构造函数时,子类必须手动通过super语句
的形式来指定访问父类中的构造函数。
当然:子类的构造函数第一行也可以手动指定this语句来访文本类中
的构造函数。子类中至少会有一个构造函数会访问父类中的构造函数。
3、final关键字
final:最终。作为一个修饰符。
1,可以修饰类,函数,变量。
2,被final修饰的类不可以被继承。继承的弊端(打破了封装性)。
为了避免被继承,被子类复写功能。
3,被final修饰的方法不可以被复写。
4,被final修饰的变量是一个常量,只能赋值一次,
即可以修饰成员变量,又可以修饰局部变量。
当在描述事物时,一些数据的出现值是固定的,那么这是为
了增强阅读性,都给这些值起个名字。方便于阅读。而这个
值不需要改变,所以加上final修饰。作为常量:常量的书写
规范所有字母都大写,如果由多个单词组成。单词间通过_连接。
修饰符:锁变量块
5,内部类只能访问被final修饰的局部变量。
原文:http://blog.csdn.net/u012332571/article/details/39804913