本帖最后由 zhoubinjian 于 2016-3-26 17:50 编辑
继承:extends
特点:1.提高了代码的复用性
2.让类与类之间产生了关系。
JAVA语言中:JAVA只支持单继承,不支持多继承。
因为多继承容易带来安全隐患,当多个父类中定义了相同的功能,当功能内容不同时,子类对象不确定要运行哪个一个。
但是JAVA保留这种机制,并用另一种体现形式来完成表示,叫多实现。
JAVA支持多层继承,也就是一个继承体系。
如何何用一个继承体系中的功能呢?
想要使用体系,先查阅体系父类的描述,因为父亲中定义的是该休系中共性功能。
通过了解共性功能,就可以知道该体系的基本功能,那么体系已经可以基本使用了。
那么在具体调用时,要创建最班班可考烦的对象,为什么呢?
1.是因为有可能父类不能创建对象。
2.创建子类对象可以使用更多的功能,包括基本的也包括特有的。
简单一句话,查阅父类功能,创建子类对象使用功能。
子父类中的函数:
当子类出现和父类一模一样的函数时,当子类对象调用该函数时,会运行子类函数的内容。就像父类的函数被覆盖一样,这种情况是函数的另一个特性:重写(覆盖)。
当子类继承父类,沿袭父类的功能到子类中,但是子类虽具备该功能,但是功能的内容却和父类不一致,这里没有必要定义新功能,而是使用覆盖特殊,保留父类的功能定义。并重写功能内容。
覆盖:
1.子类覆盖父类,必须保证子类权限大于等于父类权限,才可以覆盖,否则编译失败。
2.静态只能覆盖静态。
class Person
{
void study()
{
System.out.println("good good study");
}
}
class Student extends Person
{
void study()
{
super.study();//调用父类方法用关键词:super
System.out.println("good study");
}
}
class Demo
{
public static void main(String[] args)
{
Person p=new Student();
p.study();
}
}
子父类中的构造函数:
在对子类对象进行初始化时,父类的构造函数也会运行。
那是因为子类的构造函数默认第一行有一条隐式的语句: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");
}
Zi(int a)
{
System.out.println("zi..."+a);
}
}
class Demo
{
public static void main(String[] agrs)
{
Zi z=new Zi();
Zi z1=new Zi(4);
}
}
输出是:fu run
zi run
fu run
z...4
|
|