本文主要是介绍day12 java super的使用 Object类toString方法 多态的使用(instanceof),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
目录
super
调用父类构造器
调用父类属性
调用父类方法
Object
toString方法
多态
多态前提
多态的优点缺点
向上转型 向下转型
instanceof
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)一定要从小到大依次判断
这篇关于day12 java super的使用 Object类toString方法 多态的使用(instanceof)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!