java中instanceof的用法
2023-03-31 10:58:55 时间
一、介绍
instanceof是在多态中引出的,因为在多态发生时,子类只能调用父类中的方法(编译时类型的方法),而子类自己独有的方法(运行时类型的方法)无法调用,如果强制调用的话就需要向下转型,语法和基本类型的强制类型转换一样;但是向下转型具有一定的风险,很有可能无法成功转化,为了判断能否成功转化,就需要 instanceof 先进行一个判断,然后再进行转换操作。
二、语法
引用类型变量(object) instanceof 类(class)
三、理解
通俗点就是:什么什么…是否是…什么什么;
判断前面的对象是否属于后面的类,或者属于其子类,如果是就返回 true,若不是则返回 false。
四、注意事项
instanceof前面的引用变量编译时的类型要么与后面的类型相同,要么与后面的类型具有父子继承关系;
只要是向下转型,一定要先用instanceof继续判断后,再进行转换!
五、总结
instanceof总的来说就是在向下转型中必须使用的,可以保证自己代码的健壮性;
所以向下转型步骤是:先判断(instanceof),再转换(type)
六、案例
- 案例一
Object test01 = "Java"; // test实际类型是String,但是Object是所有类的父类 System.out.println(test01 instanceof Object); // 返回true ,因为test编译时时Object类,test可以是Object类实例 System.out.println(test01 instanceof String); // 返回true ,因为Object是String的父类,test可以是String类的实例 System.out.println(test01 instanceof Math); // 返回false ,因为Object是Math的父类,但是test不是Math类的实例 // 不符合instanceof语法规则: String test02 = "Java"; // test02是String类 System.out.println(test02 instanceof Math); // 编译出错,String类和Math类无继承关系
- 案例二
/**
* 在多态中的使用
*/
public class PolymorphismTest02 {
public static void main(String[] args) {
//此处发生多态
Person s = new Students("学生小明");
Person t = new Teachers("老师小红");
s.classes();
s.doWork();
// 无法调用students特有的方法,这时需要向下转型
// s.playing();
trans(s);
// 同理Teachers
t.classes();
t.doWork();
// 也无法调用teachers特有的方法,这时需要向下转型
// t.shopping();
trans(t);
}
// 这个函数能很好的体现出为什么需要用instancof,
// 因为你不能确定传入函数的参数到底是Teachers还是Students
public static void trans(Person p) {
if (p instanceof Students) {
Students s2 = (Students)p;
// 通过向下转型便可以调用Students特有方法了
s2.playing();
}
else if (p instanceof Teachers) {
Teachers t2 = (Teachers)p;
t2.shopping();
}
}
}
// 抽象一个人类作为父类
class Person {
String name;
public void classes() {}
public void doWork() {}
}
// 学生类
class Students extends Person {
Students(String myName) {
this.name = myName;
}
// 子类重写父类方法,覆盖了父类方法
public void classes() {
System.out.println(this.name + "在听课");
}
// 子类重写父类方法,覆盖了父类方法
public void doWork() {
System.out.println(this.name + "在写作业");
}
// 子类独有方法
public void playing() {
System.out.println(this.name + "在玩游戏");
}
}
// 老师类
class Teachers extends Person {
Teachers(String myName) {
this.name = myName;
}
// 子类重写父类方法,覆盖了父类方法
public void classes() {
System.out.println(this.name + "在上课");
}
// 子类重写父类方法,覆盖了父类方法
public void doWork() {
System.out.println(this.name + "在改作业");
}
// 子类独有方法
public void shopping() {
System.out.println(this.name + "在逛街");
}
}
相关文章
- 深入探讨Java中的异常与错误处理
- 研究学习Kotlin的一些方法
- 数据显示Java热度持续下落,日子屈指可数?
- 2017年5月编程语言排行榜:Java与C语言优势正开始缩小
- Java多线程之内置锁与显示锁
- Java线程池的理论与实践
- 白话阿里巴巴Java开发手册(编程规约)
- 关于Java你不知道的十件事
- Java服务化系统线上应急和技术攻关,你必须掌握的Linux命令
- Java实现高斯模糊和图像的空间卷积
- Java阻塞队列实现原理分析
- NPM使用技巧
- Node.js对Java开发者而言是什么?
- Java反射机制应用实践
- 理解RxJava中的Single和Completable
- 2017年你不能错过的Java类库
- 大规模集群下的Hadoop NameNode
- 从源码解密Spark内存管理
- 2017年3月编程语言排行榜:Swift首次进入前十
- JVM热点技术:Java类的加载机制