黑马程序员_面向对象(二)_JAVA_编程开发_程序员俱乐部

中国优秀的程序员网站程序员频道CXYCLUB技术地图
热搜:
更多>>
 
您所在的位置: 程序员俱乐部 > 编程开发 > JAVA > 黑马程序员_面向对象(二)

黑马程序员_面向对象(二)

 2015/5/2 22:07:49  宁远天意  程序员俱乐部  我要评论(0)
  • 摘要:-----------android培训、java培训、java学习型技术博客、期待与您交流!---------继承Java的继承通过extends关键字来实现,实现继承的类称为子类,被继承的类被称为父类。子类与父类的关系:子类是对父类的扩展,子类是一种特殊的父类。Java的子类不能获取父类的构造器。Java语言中:java只支持单继承,不支持多继承。多继承容易带来安全隐患:当多个父类中定义了相同功能,当功能内容不同时,子类对象不确定要运行哪一个。但是java保留这种机制
  • 标签:程序 程序员
----------- android培训、java培训、java学习型技术博客、期待与您交流! ---------

继承
Java的继承通过extends关键字来实现,实现继承的类称为子类,被继承的类被称为父类。子类与父类的关系:子类是对父类的扩展,子类是一种特殊的父类。Java的子类不能获取父类的构造器
Java语言中:java只支持单继承,不支持多继承。
多继承容易带来安全隐患:当多个父类中定义了相同功能,当功能内容不同时,子类对象不确定要运行哪一个。但是java保留这种机制。并用另一种体现形式来完成表示。多实现。
java支持多层继承。也就是一个继承体系
java类只能有一个直接父类,实际上可以有无限个间接父类。Java.lang.Object类是所有类的父类。

如何使用一个继承体系中的功能呢?
(查阅父类功能,创建子类对象)
想要使用体系,先查阅体系父类的描述,因为父类中定义的是该体系中共性功能。通过了解共性功能,就可以知道该体系的基本功能。那么这个体系已经可以基本使用了。那么在具体调用时,要创建最子类的对象,为什么呢?
一是因为有可能父类不能创建对象
二是创建子类对象可以使用更多的功能,包括基本的与特有的。
使用功能。
1.继承的特点
①变量
  如果子类中出现妃私有的同名成员变量是,子类要访问本类中的变量用this(代表的是本类对象的引用),子类访问父类中的同名变量用super(代表的是父类对象的引用)。super的使用和this的使用几乎一致。
②函数
当子类出现与父类同名方法时,子类对象调用该方法,运行子类函数内容,称为覆盖(重写)。
重写规则:
两同两小一大(“两同”即方法名、形参列表相同;“两小”指子类方法返回值类型应比父类方法返回值类型更小或者相等,子类方法声明抛出的异常类应比父类方法声明抛出的异常更小或相等;“一大”指子类方法的访问权限应该比父类方法的访问权限更大或相等)
注意:覆盖方法和被覆盖方法要么都是类方法,要么都是实例方法。
重载与重写区别?
重载主要发生在同一个类的多个同名方法之间,而重写发生在子类和父类的同名方法之间。当然,父类方法和子类方法之间也可能发生重载,因为子类会获得父类方法,如果子类定义了一个与父类方法有相同的方法名,但是参数列表不同,就会形成重载。
构造函数
为什么子类一定要访问父类中的构造函数?
因为父类中的数据子类可以直接获取。子类对象在建立时,需要先查看父类是如何对这些数据进行初始化的。所以子类在对象初始化时,要先访问一下父类中的构造函数。

子类调用父类的构造函数分三种情况:
a.子类构造数执行体的第一行使用super显式调用父类够着函数,系统将根据super调用里传入的实参列表调用父类对应的构造函数。
b.子类构造函数执行体的第一行代码使用this显式调用本类中重载的构造函数,系统将根据this调用里传入的是实参列表调用本类对应的另一个构造函数。执行本类中另一个构造函数时即会调用父类构造函数。
c.子类构造函数执行体重既没有super调用,也没有this调用,系统将会在执行子类构造函数前,隐式调用父类无参的构造函数。
注意:super语句一定定义在子类构造函数第一行。
2.final
最终。作为一个修饰符,可以修饰类,函数,变量。
a.被final修饰的类不可以被继承。为了避免被继承,被子类复写功能。
b.被final修饰的方法不可以被复写。
c.被final修饰的变量是一个常量只能赋值一次,既可以修饰成员变量,有可以修饰局部变量。当在描述事物时,一些数据的出现值是固定的,那么这时为了增强阅读性,都给这些值起个名字。方便于阅读。而这个值不需要改变,所以加上final修饰。作为常量:常量的书写规范所有字母都大写,如果由多个单词组成。单词间通过_连接。
d.内部类定义在类中的局部位置上是,只能访问该局部被final修饰的局部变量。
class Demo
{
final int x = 3;
public static final double PI = 3.14;
final void show1()
{}
void show2()
{
final int y = 4;
System.out.println(3.14);
}
}

3 抽象类
抽象类比一般类多个了抽象函数。就是在类中可以定义抽象方法。
抽象类不可以实例化
①抽象类的特点:
a.抽象方法一定在抽象类中。
b.抽象方法和抽象类都必须被abstract关键字修饰。
c.抽象类不可以用new创建对象。因为调用抽象方法没意义
d.抽象类中的抽象方法要被使用,必须由子类复写起所有的抽象方法后,建立子类对象调用。如果子类只覆盖了部分抽象方法,那么该子类还是一个抽象类。
特殊:抽象类中可以不定义抽象方法,这样做仅仅是不让该类建立对象。
②抽象类中是否有构造函数?
有,抽象类是一个父类,要给子类提供实例的初始化。
③abstract 关键字,和哪些关键字不能共存。
final:被final修饰的类不能有子类。而被abstract修饰的类一定是一个父类。
private: 抽象类中的私有的抽象方法,不被子类所知,就无法被复写。而抽象方法出现的就是需要被复写。
static:如果static可以修饰抽象方法,那么连对象都省了,直接类名调用就可以了。可是抽象方法运行没意义
④练习
假如我们在开发一个系统时需要对员工进行建模,员工包含 3 个属性:姓名、工号以及工资。经理也是员工,除了含有员工的属性外,另为还有一个奖金属性。请使用继承的思想设计出员工类和经理类。要求类中提供必要的方法进行属性访问。
分析:员工类:name id pay
经理类:继承了员工,并有自己特有的bonus。
class abstract 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 Manager extends Employee
{
private int bonus;
Manager(String name,String id,double pay,int bonus)
{
super(name,id,pay);
this.bonus = bonus;
}
public void work()
{
System.out.println("manager work");
}
}
class Pro extends Employee
{
Pro(String name,String id,double pay)
{
super(name,id,pay);
}
public void work()
{
System.out.println("pro work");
}
}
class 
{
public static void main(String[] args)
{
System.out.println("Hello World!");
}
}

4 模板方法设计模式
在定义功能时,功能的一部分是确定的,但是有一部分是不确定,而确定的部分在使用不确定的部分,那么这时就将不确定的部分暴露出去。由该类的子类去完成。

需求:获取一段程序运行的时间。
原理:获取程序开始和结束的时间并相减即可。
获取时间:System.currentTimeMillis();
abstract class GetTime   //定义抽象类GetTime
{
public final void getTime()    //定getTime获取程序运行时间
{
long start = System.currentTimeMillis();
runcode(); //调用runcode方法
long end = System.currentTimeMillis();
System.out.println("毫秒:"+(end-start));
}
public abstract void runcode();  //定义抽象方法runcode()
}
class SubTime extends GetTime   //定义SubTime继承GetTime
{ public void runcode()   //重写方法runcode(),
{
for(int x=0; x<4000; x++)
{
System.out.print(x);
}
}
}
class  TemplateDemo
{
public static void main(String[] args)
{
//GetTime gt = new GetTime();
SubTime gt = new SubTime();
gt.getTime();
}
}



----------- android培训、java培训、java学习型技术博客、期待与您交流! ---------
发表评论
用户名: 匿名