面向对象总结2

来源:互联网 发布:镜花缘传奇知乎 编辑:程序博客网 时间:2024/05/16 07:37


 继承(extends):

1、提高了代码的复用性

2、让类与类之间产生了关系,有了这个关系,才有了多态的特性

注意:千万不要为了获取其他类的功能,简化代码而继承,必须是类与类之间有所属关系才可以继承,所属关系:is a

Java语言中,只支持单继承,不支持多继承,因为多继承容易带来安全隐患:当多个父类(超类,基类super)中定义了相同功能,功能的内容不同时,子类对象不知该运行哪一个。

但是java保留这种机制,并用多实现形式完成表示。

Java支持多层继承,也就是一个继承体系。

想要使用体系,先查阅体系父类的描述,因为父类中定义的是该体系中共性功能,通过了解共性功能,就可以知道该体系的基本功能。

在具体调用时,要创建最子类的对象,一是有可能父类不能创建对象(抽象类和接口),二是创建子类对象可以使用更多的功能,包括基本的也包括特有的。

简单说:查阅父类功能,创建子类对象使用功能。

如果子类中出现非私有的同名成员变量,,子类要访问本类中的变量,用this,要访问父类中的同名变量,用superthis代表本类对象的引用,super代表父类对象的引用。

子父类函数的特点:

重写(覆盖)(子父类方法要一模一样):要与重载(只看同名函数的参数列表)区别开来,当子类出现和父类一样的函数时,当子类对象调用该函数,会运行子类函数的内容,如同父类的函数被覆盖一样。

覆盖注意:子类覆盖父类,必须保证子类权限大于等于父类权限,才可以覆盖,否则编译失败;静态只能覆盖静态;

子父类的构造函数:

在对子类对象进行初始化时,父类的构造函数也会运行

那是因为子类的构造函数默认第一行有一条隐式的语句super();

super():会访问父类中空参数的构造函数,而且子类中所有的构造函数默认第一行都是super();

为什么子类一定要访问父类中的构造函数:

因为父类中的数据子类可以直接获取,所以子类对象在建立时,需要先查看父类是如何对这些数据进行初始化的,所以子类在对象初始化时,要先访问一下父类的构造函数,俄国要访问父类中指定的构造函数,可以通过手动定义super语句的方式来指定。

子类的所有构造函数,默认都会访问父类中空参数的构造函数

因为子类每一个构造函数内的第一行都有一句隐式super();

final关键字:可以修饰类、方法、变量,修饰的类不可以被继承,修饰的方法不可以被覆盖,修饰的变量时一个常量,只能被赋值一次,内部类只能访问被final修饰的局部变量。

抽象类的特点:抽象方法一定定义在抽象类中,抽象方法和抽象类都必须被abstract关键字修饰,抽象类不可以用new创建对象,因为调用抽象方法没意义;

抽象类中的抽象方法要被使用,必须由子类覆写所有的抽象方法,建立子类对象调用,如果子类只覆写了部分抽象方法,那么该子类还是一个抽象类。

抽象类和一般类没有太大的不同,只是要注意该怎样描述事物就如何描述事物,只不过该事物中出现了一些看不懂的东西,这些不确定的功能,也是该事物的功能,需要明确出现,但是无法定义主体。

抽象类比一般类多了抽象函数,在类中可以定义抽象方法,不可以实例化。

抽象类可以不定义抽象方法,仅仅是不让该类建立对象。

抽象类Eg

/*

假如我们在开发一个系统时需要对员工进行建模,员工包含 3个属性:

姓名、工号以及工资。经理也是员工,除了含有员工的属性外,另为还有一个

奖金属性。请使用继承的思想设计出员工类和经理类。要求类中提供必要的方

法进行属性访问。

员工类:name id pay

经理类:继承了员工,并有自己特有的bonus

*/

class Employee

{

       private String name;

       private String id;

       private double salary;

       Employee(String name,String id,double salary)

       {

              this.name=name;

              this.id=id;this.bonus=bonus;

       }

       public abstract void work();

}

class Manager extends Employee

{

       private double bonus;

       Manager(String name,String id,double salary,double bonus)

       {

              super(name,id,salary);

              this.bonus=bonus;

       }

       public void work()

       {

              System.out.println("Manager work");

       }

}

class Worker extends Employee

{

       Worker(String name,String id,double pay)

       {

              super(name,id,salary);

       }

       public void work()

       {

              System.out.println("Worker work");

       }

}

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

接口(interface):初期理解,可以认为是一个特殊的抽象类,当抽象类中的方法都是抽象的,那么该类可以通过接口的形式来表示。

       接口是对外暴露的规则,是程序的功能扩展,可以用来多实现

1、接口中常见定义:常量、抽象方法

2、接口中的成员都有固定修饰符

常量:public  static  final

方法:public  abstract

记住:接口中的成员都是public的,接口是不可以创建对象的,因为有抽象方法,需要被子类实现(implements),子类对接口中的抽象方法全都覆盖后,子类才可以实例化,否则子类是一个抽象类。

接口可以被类多实现,也是对多继承不支持的转换形式。

[类与类之间继承,类与接口之间实现,接口与接口之间继承]

基本功能定义在类中,扩展功能定义在接口中。

多态:可以理解为事物存在的多种体现形态。

多态的体现(父类的引用也可以接收自己的子类对象)、多态的前提(必须类与类之间有关系,要么继承,要么实现,另外还要存在覆盖)、多态的弊端(只能使用父类的引用访问父类中的成员)、多态的好处(大大提高了程序的扩展性)、多态的应用。

向下转型:强制将父类的引用,转成子类类型

                    如动物和猫的例子:Cat c=Cata

成员函数在运行时:编译看左边,运行看右边。

在多态中,成员变量无论编译还是运行,都参考左边(引用型变量所属的类);

多态的主板实例

class MainBoard

{

       public void run()

       {

              System.out.println("mainboard run");

       }

       public void usePCI(PCI p)

       {

              if(p!=null)

              {

                     p.open();

                  p.close();     

              }

      

       }

}

interface PCI

{

       public void open();

       public void close();

}

class Network implements PCI

{

             public void open()

             {

                    System.out.println("network work");

             }

             public void close()

             {

                    System.out.println("network close");

             }

}

class DuotaiDemo4

{

       public static void main(String[] args)

       {

              MainBoard mb=new MainBoard();

              mb.run();

              mb.usePCI(new Network());

       }

}

object:所有对象的直接或者间接父类,该类中定义的肯定是所有对象都具备的功能。

object类中已经提供了比较对象是否相同的方法,如果自定义类中也有比较相同的功能

,没有必要重新定义,只要沿袭父类中的功能,建立自己特有的比较内容即可,这就是覆盖。

toString():返回对象的字符串表示。