目录
super
super可以调用属性,方法,构造器 super可以理解成"父类的"
调用父类构造器
格式: super([形参列表])
1.super([形参列表])必须放在子类的构造器中。 2.super([形参列表])必须放在构造器的首行。super([形参列表])在同一个构造器中只能有一个。 3.如果在子类中没有显示的调用super([形参列表])和this([形参列表])默认调用的是父类的空参构造器 4.创建子类对象必调父类构造器--(因为父类中的构造器可能会存在一定要初始化的事情) (因为如果有N个构造器最多只能有N-1个this(形参列表) 如果子类的构造器中没有this(形参列表)默认就调父类的空参构造器)
class SuperA{
int a;
//构造器
public SuperA(){
System.out.println("SuperA()");
}
//构造器
public SuperA(int a){
this.a = a;
System.out.println("SuperA(int a)");
}
}
class SubA extends SuperA{
public SubA(){
//调用父类的构造器
super();//调用的是父类的空参构造器
//super(1);//调用的是父类的有参构造器
System.out.println("SubA()");
}
public SubA(int a){
this();
System.out.println("SubA(int a)");
}
}
public class SuperTest2 {
public static void main(String[] args) {
new SubA(1);
}
}
注意:1.调用父类构造器是一层一层向上调 2.创建子类对象那么子类会调用父类的构造器但是只创建了子类一个对象。
调用父类属性
当子类继承父类后如果子类有和父类一样名字的属性。那我们又要调用父类中的属性这时就必须在该属性名前加"super."(注意:这不是重写,方法可以重写但是属性不能重写) 当子类继承父类后如果子类没有和父类一样名字的属性.那我们要调用父类中的属性这就属性名前的"super."可加可不加 注意:如果调用父类的属性时前面没有加"super."该属性就会产生不确定因素-一旦子类声明了和父类一样名字的属性,那么调用的就是子类的。 如果没有声明一样名字的属性那么调用的就是父类的。
调用父类方法
当子类继承父类后如果子类重写了父类的方法。那么我们要调用父类被重写的方法就必须加"super." 如果没有重写父类的方法那么调用父类的方法时"super."可加可不加。 注意:如果调用父类的方法时前面没有加"super."该方法就会产生不确定因素---一旦子类重写就变成调用子类重写的方法。如果没有重写就是父类的方法。
Object
Object类: 1.Object是所有类的父类(基类,超类) 2.当一个类如果没有显示的继承其它类那么默认继承Object类。 3.所有对象包括数组都实现了Object中的方法(可以调用Object中的方法)。
toString方法
一 Object中的toString方法 public String toString() { return getClass().getName() + "@" + Integer.toHexString(hashCode()); } getClass().getName() :获取类的全类名 Integer.toHexString() :将数值转成十六进制 hashCode() : 获取哈希值(哈希码)-- 每个对象都有属于自己的哈希码(可以通过哈希码区分对象) 二 我们发现核心类库中的类基本上都重写了Object中的toString方法。用来输出内容而非地址值。 如果是自定义的类建议也重写toString方法输出内容而非地址值。
多态
多态前提
①要有继承性 ②要有方法的重写 ③一定要父类的引用指定子类的对象
注意:属性没有多态性(属性能重写?-不能)
编译看左边 运行看右边
多态的优点缺点
优点:提高代码的灵活性,扩展性,简化代码结构 缺点:不能调用子类独有的属性和方法 (因为编译看左边-在编译的时候看不到(左边是父类)右边对象中的内容)
向上转型 向下转型
向上转型 :在编译的时候将子类的对象以父类的形态呈现。( 多态(父类的引用指向子类的对象)) 向下转型:让一个父类的变量在编译期间以子类的形式呈现即可 为什么要向下转型?为了使用子类独有的属性和方法。
instanceof
在向下转型的时候有可能会发生ClassCastException 如何避免ClassCastException ? 可以使用instanceof进行类型判断再向下转型。 格式 : 对象 instanceof 类名或者接口名(翻译为 对象 属不属于 该类 或者 该接口) 说明: 1.判断对象是否属于右边的类的类型。 2.返回值为布尔类型。 3.在使用向下转型时一定要先类型判断。
1. C 继承 B B继承 A 当我们创建B类的对象时 用该对象和上面三个类instanceof发现 和B类结果为true 和A类(父类)结果为true(向上(当前类继承上面所有的)不向下(当前类和子类没关系)) 2.如果是在if -else if中进行类型判断(instanceof)一定要从小到大依次判断