接口与继承
接口:约定
对象转型
引用类型(调用函数)和对象类型(类)
通常情况下引用类型和对象类型一致,不相同时需要转换
子类转父类——一定能够成功
父类转子类——分情况看是否成功
把h转换成AD类型需要强制转换,如果h和AD指向同一个类型可以转换成功,否则强制转换失败,强制转换有风险
没有相互之间继承关系的两个类转换一定失败
实现类转换成接口(向上转型)
接口转换成实现类(向下转型)
instanceof判断时候是主类型或者是主类型的子类型
重写
定义:子类可以继承父类的对象方法。在继承后,重复提供该方法,就叫做方法的重写。又叫覆盖 override
在父类中存在的的方法,在子类中发生重复执行的是子类中重写的方法
多态
操作符的多态:+:如果两侧都是整形是运算
两侧任意一个是字符串,执行连接
观察类的多态:子类不同,在输出时根据子类输出
类的多态条件:要实现类的多态,需要如下条件
\1. 父类(接口)引用指向子类对象
\2. 调用的方法有重写
使用多态:主要的意义就是减少工程量,调用方法修改简便,类的调用
隐藏
super关键字
在子类方法调用的时候,默认会调用父类的无参的方法如何改变能够调用父类的有参的方法?
采用super在子类中的方法运用super(参数),调用父类中指定的构造方法;super()
调用属性:采用super.属性调用父类的属性;采用this.属性调用当前的属性
方法调用:super.构造方法
减少开发的成本,
object类
object是所有类的父类
tostring()返回当前对象的字符串表达
finalize()垃圾回收站
hashCode()
线程同步相关方法
getClass()
final
final修饰类,方法,基本类型变量,引用的时候分别有不同的意思。
修饰类:当Hero被修饰成final的时候,表示Hero不能够被继承
其子类会出现编译错误
final修饰方法:Hero的useItem方法被修饰成final,那么该方法在ADHero中,不能够被重写
修饰节本类型变量:final修饰基本类型变量,表示该变量只有一次赋值机会
final修饰引:h引用被修饰成final,表示该引用只有1次指向对象的机会
常量:常量指的是可以公开,直接访问,不会变化的值
抽象类
抽象方法:public abstract iiii();父类声明抽象方法
父类存在抽象方法的时候,子类必须重写这个方法,不同的子类有不同的方法
抽象类可以没有抽象方法,但是如果没有抽象方法了,抽象类不能直接使用需要继承使用
抽象类和接口的区别
区别1:
子类只能继承一个抽象类,不能继承多个
子类可以实现多个接口
区别2:
抽象类可以定义
public,protected,package,private
静态和非静态属性
final和非final属性
但是接口中声明的属性,只能是
public
静态
final的
即便没有显式的声明
内部类:在类的下面在整出来一个类
非静态内部类不是stactic实例化时候是:外部类.内部类.,,,,
静态内部类有:加上stactic实例化时候是:内部类.,,,,不需要外部类访问
匿名类:有些抽象方法
相当于一个子类;使用外部的局部变量的时候,需要用final进行修饰
本地类:在方法里创建一个类。匿名类是一种本地类
默认方法
JDK8接口可以提供具体方法了,而不仅仅是抽象方法需要加上default