三大特征
封装
概述
程序的设计应该追求 高内聚,低耦合
高内聚:内部实现的细节隐藏起来,不允许外界来干涉
低耦合:不能直接访问内部数据,只能通过操作接口来访问内部的数据
封装的实现
属性私有,get/set
封装的意义
1.提高程序的安全性,保护数据
2.隐藏代码的实现细节
3.统一接口
4.系统的可维护性增加了
记住一句话:属性私有,get/set
继承
概述
继承是类和类之间的一种关系,除此之外,类和类之间还有依赖,组合,聚合等关系
继承关系的两个类,一个为子类(派生类),一个为父类(基类),子类继承父类,用关键字 extends 表示
子类和父类在意义上讲是 “ is a ”的关系 比如: 猫是动物
子类继承父类,就会拥有分类的所有公共(public)方法,私有的属性和方法无法被继承
Ctrl+h 打开类的继承图
Object类
在java中 Object类是所有类的父类,在java中只有单继承(一个儿子只有一个父亲,但是一个父亲可以有多个儿子)
super 关键字
作用
调用父类的构造器,必须在子类构造器的第一行
子类构造器会默认调用父类的无参构造
super-this关键字比较
1.使用的前提不同
this:不用继承也可以使用 super:需要在继承的条件下才能使用
2.代表的对象不同
this:代表调用者本身这个对象 super:代表父类对象的引用
3.构造方法不同
this() : 调用的本类的构造 super():调用的父类的构造
注意
1.调用父类的构造方法,而且必须在构造方法的第一行
2.super 只能出现在子类的方法或者构造方法中
3.super和this不能同时调用构造方法
方法的重写
概述
相同的方法签名,不同的方法实现
方法的调用只和左边数据的类型有关
父类的引用指向子类对象(多态)
前提
需要有继承关系,子类重写父类的方法
注意
1.方法名必须相同
2.参数列表必须相同
3.修饰符范围可以扩大,不可以缩小 public > protected > default > private
4.抛出的异常:范围可以缩小,不可以扩大
为什么需要重写?
父类的功能(方法),子类不一定需要或者不一定满足,所以子类需要自己去实现方法
父类引用指向子类对象,当子类重写了父类的方法时,调用方法时就会调用子类重写的方法
子类能否重写父类的静态方法?
答案是不能
结论:
会产生这个结果的原因显而易见,子类重写了父类的静态方法,但是并没有将其覆盖,二者之间仍然独立,所以类型是父类Super的变量,调用的仍然是父类的静态方法,而不是子类的重写方法。也就是说子类并不能重写父类的静态方法。
解释:
首先要明确一个概念,静态方法属于类,在编译阶段类被加载时,类的静态方法或者属性就会被分配内存,存储到类所在的内存中(堆内存的方法区中);而类的非静态方法却是属于对象的,每个对象都有一份非静态方法的引用,并且若方法被重写,引用的就是子类重写的方法,且这是在运行时创建;
正因如此,即使子类重写了父类的静态方法,但是本质上它们还是两个独立的类,在内存中分别占用不同的内存,它们的静态方法也是在编译时就被加载,独立的占用着不同的内存。一个父类的引用,指向子类的对象,调用一个被子类重写的静态方法时,由于这是一个父类的变量,并且静态方法属于类,所以在调用时,JVM会去父类所在的内存中寻找这个方法,所以最终的结果就是调用父类的方法,而不是子类重写的方法。
无法重写的方法:
1.static 修饰的方法,是属于类的
2.final 修饰的方法 常量池里
3.private 修饰的方法
多态
概述
同一方法根据调用方法的不同的引用执行多种不同的行为
一个对象的实际类型是确定的,但是指向对象的引用的类型有很多
多态的条件
1.继承关系
2.子类重写父类的方法
3.父类引用指向子类对象
注意
多态是方法的多态,不是属性的多态
调用方法时是编译的时候决定调用哪个方法
父类型可以指向子类型对象,但是没办法调用子类独有的方法
对象能调用哪些方法主要是看对象左边的类型
当父类方法与子类方法重名,并且子类没有重写父类的方法,调用谁的方法由对象的实际类型决定
转型
向上转型
安全的,不需要强制转换,会丢失本来子类的一些方法
向下转型
不安全的,需要检查类型,然后进行强制类型转换
转型的意义
方便方法的调用,减少重复代码