java继承封装多态
梳理继承、封装、多态、重载、构造器、重写覆盖、this/super、动态绑定
引出新技术的原因
这些技术都是为了解决一些出现的问题或者是满足一些必要的需求而提出,从而使代码更加简洁易于维护,复用性更强。
文章目录
1、重载
-
问题:解决多个方法重名的存在
-
好处:减轻了起名,记名的麻烦
-
要点:
(1)方法名必须相同
(2)形参列表不同——数目、顺序、类型
(3)返回类型无要求 -
案例:
calculate(int n1,int n2)//顺序
calculate(int n2,int n1)//顺序、数目
calculate(int n2,int n1,double n3)//类型
2、构造方法
- 问题:创建对象时,就完成对象的初始化
- 好处:构造器又叫构造方法,是类的一种特殊的方法,他的主要作用是完成新对象的初始化。
- 要点:
(1)一个类可以定义多个不同的构造器,即构造器的重载
(2)构造器名和类名相同
(3)构造器没有返回值
(4)构造器是完成对象的初始化,不是创建对象
(5)在创建对象时,系统自动的调用该类的构造器进行初始化
(6)如果没有定义构造器,系统会自动给类生成一个默认无参构造器(默认构造器)
(7)一旦定义了自己的构造器,默认的构造器就被覆盖了,就不能在使用默认的无参构造器了,除非显示写出来 Dog(){} - 案例:
class Dog{
Dog (){}
public Dog (string name ){
this.name=name;
}
}
3、this关键字
-
问题:重名
-
好处:解决属性(成员变量)与局部变量冲突的问题
-
要点:
(1)本类中谁调用,就代表哪个对象
(2)只能是本类中使用 -
三个应用:
(1)this调用本类中的属性也就是成员变量
(2)this调用本类中的其他成员方法通常不写
(3)this调用本类中的其他构造方法,调用时要放在构造方法的首行
(4)return this 作为类的返回值
4、封装
- 好处:
(1)隐藏细节方法连接数据库,调用传入参数
(2)可以对数据进行验证,保证安全合理 - 封装的实现步骤:
(1)将属性私有化private,不能直接修改属性
(2)提供一个公共的(public)set方法,用于对属性的判断和赋值
(3)提供一个公共的(public)get方法,用于获取属性的值
5、继承
-
问题:两个类的属性方法,有很多相同的
-
好处:
(1)提高了代码的复用性
(2)代码的维护性,扩展性提高了 -
要点:
(1)子类继承了所有的属性方法,非私有属性和方法可以在子类直接访问,但是私有属性和方法不能在子类直接访问,要通过父类提供公共的方法去访问
(2)子类必须调用父类的构造器完成父类的初始化,super,在继承
(3)当创建子类对象时,不管使用子类的哪个构造器,默认情况下总会去调用父类的无参构造器。如果父类没有提供无参构造器,则必须在子类的构造器中用super去指定使用父类的哪个构造器完成是对父类的初始化工作,否则,编译不会通过。因为子类要继承嘛所以父类要初始化。
(4)如果希望去调用父类的某个构造器,则显示的调用一下:super(参数列表)
(5)super在使用时,必须放在构造器的第一行。super只能在构造器中使用
(6)super在子类调用父类,this在本类,super和this都放在第一行,所以不能共存在一个构造器
(7)java所有类都是Object类的子类,Object是所有类的父类顶级父类
(8)父类构造器的调用不限于直接父类,将一直往上追溯,知道找到或者Object类
(9)子类最多只能继承一个父类(指直接继承),即java中是单继承机制。
(10)不能滥用继承,子类和父类之间必须满足is-a的逻辑关系 -
继承的本质:当子类对象创建好后,建立好查找关系
6、super
- 概念:super代表父类的引用,用于访问父类的属性,方法,构造器。
- 语法:
(1)访问父类的属性,但不能访问父类的private属性 super.属性名;
(2)访问父类的方法,不能访问父类的private方法 super.方法名(参数列表);
(3)访问父类的构造器super(参数列表);只能放在构造器的第一句,只能出现一句! - 好处:
(1)调用父类的构造器的好处:分工明确,父类属性由父类初始化,子类的属性由子类初始化
(2)当子类中有和父类中的成员(属性/方法)重名时,为了访问父类的成员,必须通过super。如果没有重名,使用super、this直接访问是效果一样
(3)super的访问不限于直接父类,如果爷爷类和本类中有同名的成员也可以使用super去访问爷爷类的成员;如果多个基类中都有同名的成员,使用super访问遵循就近原则。当然也需要遵守访问权限的相关规则
7、super和this比较
8、重写/覆盖
-
方法重写也叫覆盖
-
子类方法的形参列表,方法名称,要和父类方法的形参列表方法名称完全一样
-
子类方法的返回类型和父类方法返回类型一样,或者是父类返回类型的子类。
比如,父类返回类型是object,子类方法返回类型是string -
子类方法不能缩小父类方法的访问权限
-
重载、重写比较:
9、动态绑定
- 当调用对象方法的时候,该方法会和该对象的内存地址/运行类型绑定
- 当调用对象属性时,没有动态绑定机制,哪里声明,哪里使用
10、多态
1、多态概述
-
多态是继封装、继承之后,面向对象的第三大特性。
-
多态现实意义理解:
-
提高代码复用性
-
现实事物经常会体现出多种形态,如学生,学生是人的一种,则一个具体的同学张三既是学生也是人,即出现两种形态。
-
Java作为面向对象的语言,同样可以描述一个事物的多种形态。如Student类继承了Person类,一个Student的对象便既是Student,又是Person。
- 多态体现为父类引用变量可以指向子类对象。
- 前提条件:必须有子父类关系/两个对象存在继承关系。注意:在使用多态后的父类引用变量调用方法时,会调用子类重写后的方法。
- 理解:
多态是同一个行为具有多个不同表现形式或形态的能力。
多态就是同一个接口,使用不同的实例而执行不同操作。
2、多态中成员的特点
- 属性没有重写之说,属性的值看编译类型
- 方法的多态(重写重载就体现多态)
- 对象的多态:
(1)一个对象的编译类型和运行类型可以不一致
(2)编译类型在定义对象时,就确定了,不能改变
(3)运行类型是可以变化的
(4)编译类型看定义时 = 号的左边,运行类型看 = 号的右边
(5)编译看左边运行看右边
(6)instanceOf比较操作符,用于判断对象的运行类型是否为XX类型或XX类型的子类型
3、多态向上转型
- 本质:父类引用指向子类对象
- 语法:父类类型 引用名 = new 子类类型();
- 特点:编译类型看左边,运行类型看右边。
可以调用父类中的所有成员(需遵守访问权限),不能调用子类中特有成员;最终运行效果看子类的具体实现!
4、多态向下转型
- 语法:子类类型 引用名 = (子类类型) 父类引用;
- 只能强转父类的引用,不能强转父类的对象
- 要求父类的引用必须指向的是当前目标类型的对象
- 当向下转型后,可以调用子类类型中所有的成员