---------------------- <a href="http://edu.youkuaiyun.com/heima" target="blank">android培训</a>、<a href="http://edu.youkuaiyun.com/heima" target="blank">java培训</a>、期待与您交流! ----------------------
继承是面向对象语言的重要机制。借助继承,可以扩展原有的代码,应用到其他程序中,而不必重新编写这些代码。在java语言中,继承是通过扩展原有的类, 声明新类来实现的。扩展声明的新类称为子类,原有的类称为超类(父类)。继承机制规定,子类可以拥有超类的所有属性和方法,也可以扩展定义自己特有的属 性,增加新方法和重新定义超类的方法。
继承的优点:
1,提高了代码的复用性
2,让类之间产生了关系。有了这个关系,才有了多态的特性
注意:千万不要为了获取其他类的功能,简化代码而继承, 必须是类与类之间有所属关系才可以继承,所属关系is a。
子类父类出现后,类成员的特点:
1,变量
如果类中出现非私有的同名成员变量时子类要访问本类中的变量,用this;子类要访问父类中的同名变量,用supper。
supper的使用和this的使用几乎一致,this代表的是本类对象的引用,supper代表的是父类对象的引用。
2,函数
当子类出现和父类一模一样的函数时,当子类对象调用该函数,会运行子类函数的内容,如同父类的函数被覆盖一样,这中情况是函数的另一个特性:重写(覆盖)。当子类继承了父类,沿袭了父类的功能到子类中,但是子类虽具备该功能,但是功能的内容却和父类不一致,这时,没有必要定义新功能,而是使用覆盖特性,保留父类功能的定义,并重写功能内容。
覆盖注意事项:
1,子类覆盖父类,必须保证子类权限大于等于父类权限,才可以覆盖,否则编译失败。
2,静态只能覆盖静态。
注意:重载:只看同名函数的参数列表;重写:子父类的方法要一模一样。
3,构造函数
在对子类对象进行初始化时,父类的构造函数也会进行,那是因为子类的构造函数默认第一行有一条隐式语句supper(),supper();会访问父类中空参数的构造函数,而且子类中所有的构造函数默认第一行都是supper();。
为什么子类一定要访问父类中的构造函数
因为父类中的数据子类可以直接获取,所以子类对象在建立时,需要先查看父类是如何对这些数据进行初始化的。所以子类在对象初始化时,先要访问一下父类中的构造函数,如果要访问父类中指定的构造函数,可以通过手动定义supper语句来指定。
注意:supper语句一定定义在子类构造函数的第一行。
子类的实例化过程:
结论:子类所有的构造函数默认都会访问父类中空函数的构造函数,因为子类没一个构造函数的第一行都有一句隐式supper();。
当父类中没有空参数的构造函数时,子类必须手动通过supper或者this语句形式来指定要访问的构造函数。
当然:子类的构造函数第一行也可以手动指定this语句来访问本类中的构造函数。子类总至少会有一个构造函数会访问父类中的构造函数。
例子一:
假设我们在开发一个系统时需要对员工进行建模,员工包含3个属性:姓名,工号以及工资,经理也是员工,除了包含员工的属性外还有一个奖金属性。请使用继承的思想设计出员工类和经理类。要求类中提供必要的方法进行属性访问。
/*
分析:
员工类:name id pay
经理类:继承了员工,并有自己的bonur
*/
class Employee
{
private String name;
private String id;
private double pay;
Employee(String name,String id,double pay)
{
this.name=name;
this.id=id;
this.pay=pay;
}
public abstract void work();
}
class Manger extends Employee
{
int bonus;
Manger(String name,String id,double pay,int bonus)
{
super(name,id,pay);
this.bonus=bonus;
}
public void work()
{
System.out.print("Manger work")
}
}
class Proextends Employee
{
pro (String name,String id,double pay)
{
super(name,id,pay);
}
public void work()
{
System.out.print("Pro work")
}
}
class
{
public static void main(String[] args)
{
System.out.print("hello world!")
}
}
例子二:
/*
需求:获取一段程序运行的时间
原来:获取程序开始和结束的时间并相减即可
获取时间:System.currentTimeMillis();
当代码完成优化后就可以解决这类问题
这种方式,叫做模版方法设计模式
什么是模版方法呢?
在定义功能时,功能的一部分是确定的,但是有一部分是不确定的,而确定的部分在使用不确定的部分,
那么这时就将不确定的部分暴露 出去,由该类的子类去完成
*/
abstract class GetTime
{
public final void getTime()
{
long start=System.currentTimeMillis();
runcode();
long end=System.currentTimeMillis();
System.out.println("运行的时间"+(end-star));
}
public abstract void runcode();
}
class SubTime extends GetTime
{
public void runcode()
{
for(int x=0;x<3000; x++)
{
System.out.print(x);
}
}
}
class Temp
{
public static void main(String[] args)
{
SubTime gt=new SubTime();
gt。getTime();
}
}
---------------------- <a href="http://edu.youkuaiyun.com/heima" target="blank">android培训</a>、<a href="http://edu.youkuaiyun.com/heima" target="blank">java培训</a>、期待与您交流! ----------------------
详细请查看:<a href="http://edu.youkuaiyun.com/heima" target="blank">http://edu.youkuaiyun.com/heima</a>