instanceof
我们先创建4个类
Application Person Student Teacher
这4个类
其中Teacher 继承 Person
Student 继承 Person
我们在Application类里面new一个Student
然后把引用类型改成Object
//Object > String
//Object > Person > Teacher
//Object> Person > Student
我们运行一下
前面3个为true是因为前面三个都是Object引用类型 和 Student实际类型的父与子之间的继承关系
而Teacher为什么为false 是因为Teacher是跟Person 为父子关系, 与Student 无关
String 是Java.lang包下的,跟Student 没有什么关系 所以也为true
我们在new一个Student
将引用类型改成Person
就会发现下面String类型已经报错了(编译报错了) 因为Person 和 String没有什么关系
我们在输入new 一个 Student
应用类型为Student
就会发现下面报错2行
因为instanceof是比较转换的过程, 只有2遍有关系 他才会返回true 或false
如果没有关系他就会直接报错 编译报错
System.out.println(X instanceof Y);
//取决于X是否与Y有继承关系,且类X是实例x的引用类型 //能不能编译通过 就是来证明,X和Y直接是否存在父子关系 有 为 true 没 为 false
类型转换
我们在Student类里面写一个go方法
public void go(){
System.out.println("go");
}
在Person类里面写一个run方法
public void run(){
System.out.println("run")
}
类型之间的转化: 父 ->子
我们new一个Student 把引用类型改成Person
//高 低
Person s1 = new Student();
我们调用一下go方法
发现报错了
我们必须把s1 (Person)类型给转换成Student 就可以使用Student类型的方法了
Student student = (Student) s1;
student.go();
就可以调用了
当然我们也可以
((Student)s1).go();
这样进行强制转换
我们在new一个Student
我们想把Student转换成Person类型
Person person = student;
//低转高 自动转换
但是注意
子类型转父类型会丢失自己本身的方法
总结
/*
* 1.父类引用指向子类对象
* 2.把子类转换成父类,向上转型:不用强制转换
* 3.把父类转换成子类, 需要强制转换 :可能会丢失方法
* 4.方便方法的调用,减少重复的代码!简洁
* 抽象:封装、继承、多态
*
*子转父:向上转型,直接转,丢失子类中原版可直接调用的特有方法;父转子:向下转,可能会损失精度
*
* 低(子)转高(父),由于子以及继承了父的所有,所以删去属于自己的属性然后自然而然就可以转化为父类的;
* 而父转子,则需要重写开辟只属于子的空间,则需要强制转换
* */