继承
-
继承的本质是对某一批类的抽象,从而实现对现实世界更好的建模
-
extends 的意识是“扩展”。子类是父类的扩展。
-
Java 中的类只有单继承,没有多继承!
-
继承是类和类之间的一种关系,除此之外,类和类之间的关系还有以来、组合、聚合等等
-
继承关系的两个类,一个为子类(派生类),一个为父类(基类)。子类继承父类,使用关键字 extends 来表示
-
子类和父类之间,从意义上讲应该具有“ is a ”的关系
-
(private) 私有的东西无法被继承
object 类
- Java 中,所有的类,都默认直接或间接继承 Object
super & this(重点)
super:
- super 调用父类的构造方法,必须在构造方法的第一行
- super 必须只能出现在子类的方法或者构造方法中
- super 和 this 不能同时调用构造方法!
this:
- this() 必须放在构造器的首行。【this() 等同于调用构造器】
- 使用 this 调用本类中其他的构造器,保证至少有一个构造器是不用 this 的(实际上就是不能出现构造器自己调用自己)
- this 表示当前对象,可以调用类的属性、方法和构造器。
- this 在方法内部使用,即这个方法所属对象的引用;
- this 在构造器内部使用,表示该构造器正在初始化的对象;
- super 与 this 的区别:
- 代表对象不同:
- this:本身调用者这个对象
- super:代表符类对象的应用
- 前提:
- this:没有继承也可以使用
- super:只能在继承条件才可以使用
- 构造方法:
- this():本类的构造
- super() :父类的构造
- 代表对象不同:
方法重写(重点)
- 需要有继承关系,子类重写父类的方法!
- 方法名必须相同
- 参数列表必须相同
- 修饰符:范围可以扩大,但不能缩小( Public > Protected > Default > Private )
- 抛出的异常:范围可以被缩小,但不能扩大
- 子类的方法和父类的必须一致,但方法体可以不同!
静态的方法和非静态的方法区别很大
//静态方法:方法的调用只和左边,定义的数据类型有关(加了 static)
public class A { //父类
public static void print(){
System.out.println("A-->test()");
}
}
public static class B extends B{ //子类
public void print(){
System.out.println("B-->test()");
}
}
public static void main(String[] args){ //测试类
//父类的引用指向了子类
A a = new A();
a.test(); //A-->test()
// 方法的调用只和左边,定义的数据类型有关
B b = new A();
b.test(); //B-->test()
} // 不属于重写
//非静态的方法:
public class A { //父类
public void print(){
System.out.println("A-->test()");
}
}
public class B extends B{ //子类
public void print(){
System.out.println("B-->test()");
}
}
public static void main(String[] args){ //测试类
A a = new A();
a.test(); //B-->test()
// 方法重写
B b = new A();
b.test(); //B-->test()
}
在Java中,如果父类中含有一个静态方法,且在子类中也含有一个返回类型、方法名、参数列表均与之相同的静态方法,那么该子类实际上只是将父类中的该同名方法进行了隐藏,而非重写。换句话说,父类和子类中含有的其实是两个没有关系的方法,它们的行为也并不具有多态性。
为什么需要重写?
- 父类的功能,(父类功能过多)子类不一定需要,或者(父类功能太少)不一定满足!
Atl + Insert --> Override