Java中instanceof
2016-06-13 12:31
225 查看
今天在学习一段代码的时候,看到以下
[java] view plaincopy
if(colleague instanceof RentHouse){
// …
}
其中包含的关键字instanceof自己是第一次看到,查阅有关资料后,自己知道了它的用法,现在来写一篇博客谈一下吧。
二、正文:
经过百度,我们可以知道:instanceof是Java的一个二元操作符,和==,>,<是同一类东东。由于它是由字母组成的,所以也是Java的保留关键字。它的作用是测试它左边的对象是否是它右边的类的实例,返回boolean类型的数据。举个例子:
String s = “I am an Object!”;
boolean isObject = s instanceof Object;
我们声明了一个String对象引用,指向一个String对象,然后用instancof来测试它所指向的对象是否是Object类的一个实例,显然,这是真的,所以返回true,也就是isObject的值为True。
下面举自己写的一个详细的例子:
[java] view plaincopy
class Vehicle{ // 交通工具
// …
}
class Bicycle extends Vehicle{ // 自行车
// …
}
class Car extends Vehicle{ // 小轿车
// …
}
public class Test {
public static void Type(Vehicle vehicle){
if(vehicle instanceof Bicycle){
System.out.println(“Bicycle的上转型对象”);
}
if(vehicle instanceof Car){
System.out.println(“Car的上转型对象”);
}
}
public static void main(String[] args) {
Vehicle vehicle = new Vehicle();
Bicycle bicycle = new Bicycle();
Car car = new Car();
Vehicle vehicle_bicycle = new Bicycle();
Vehicle vehicle_car = new Car();
System.out.println(vehicle instanceof Vehicle); // 输出结果为:ture
System.out.println(bicycle instanceof Bicycle); // 输出结果为:ture
System.out.println(car instanceof Car); // 输出结果为:ture
System.out.println(vehicle_bicycle instanceof Bicycle);// 输出结果为:ture
System.out.println(vehicle_car instanceof Car); // 输出结果为:ture
Type(vehicle_bicycle); // 输出结果为:Bicycle的上转型对象
Type(vehicle_car); // 输出结果为:Car的上转型对象
}
}
上述的Type()方法实现了用一个方法处理两种子类。
然而,这种做法通常被认为是没有好好利用面向对象中的多态性。其实上面的功能要求用方法重载完全可以实现,这是面向对象变成应有的做法,避免回到结构化编程模式。只要提供两个名字和返回值都相同,接受参数类型不同的方法就可以了:
[java] view plaincopy
public static void Type(Bicycle vehicle){
// …
}
public static void Type(Car vehicle){
// …
}
所以,使用instanceof在绝大多数情况下并不是推荐的做法,应当好好利用多态。
[java] view plaincopy
if(colleague instanceof RentHouse){
// …
}
其中包含的关键字instanceof自己是第一次看到,查阅有关资料后,自己知道了它的用法,现在来写一篇博客谈一下吧。
二、正文:
经过百度,我们可以知道:instanceof是Java的一个二元操作符,和==,>,<是同一类东东。由于它是由字母组成的,所以也是Java的保留关键字。它的作用是测试它左边的对象是否是它右边的类的实例,返回boolean类型的数据。举个例子:
String s = “I am an Object!”;
boolean isObject = s instanceof Object;
我们声明了一个String对象引用,指向一个String对象,然后用instancof来测试它所指向的对象是否是Object类的一个实例,显然,这是真的,所以返回true,也就是isObject的值为True。
下面举自己写的一个详细的例子:
[java] view plaincopy
class Vehicle{ // 交通工具
// …
}
class Bicycle extends Vehicle{ // 自行车
// …
}
class Car extends Vehicle{ // 小轿车
// …
}
public class Test {
public static void Type(Vehicle vehicle){
if(vehicle instanceof Bicycle){
System.out.println(“Bicycle的上转型对象”);
}
if(vehicle instanceof Car){
System.out.println(“Car的上转型对象”);
}
}
public static void main(String[] args) {
Vehicle vehicle = new Vehicle();
Bicycle bicycle = new Bicycle();
Car car = new Car();
Vehicle vehicle_bicycle = new Bicycle();
Vehicle vehicle_car = new Car();
System.out.println(vehicle instanceof Vehicle); // 输出结果为:ture
System.out.println(bicycle instanceof Bicycle); // 输出结果为:ture
System.out.println(car instanceof Car); // 输出结果为:ture
System.out.println(vehicle_bicycle instanceof Bicycle);// 输出结果为:ture
System.out.println(vehicle_car instanceof Car); // 输出结果为:ture
Type(vehicle_bicycle); // 输出结果为:Bicycle的上转型对象
Type(vehicle_car); // 输出结果为:Car的上转型对象
}
}
上述的Type()方法实现了用一个方法处理两种子类。
然而,这种做法通常被认为是没有好好利用面向对象中的多态性。其实上面的功能要求用方法重载完全可以实现,这是面向对象变成应有的做法,避免回到结构化编程模式。只要提供两个名字和返回值都相同,接受参数类型不同的方法就可以了:
[java] view plaincopy
public static void Type(Bicycle vehicle){
// …
}
public static void Type(Car vehicle){
// …
}
所以,使用instanceof在绝大多数情况下并不是推荐的做法,应当好好利用多态。
相关文章推荐
- Java易错知识点笔记
- Struts2学习【1】第一个完整程序
- Spring 视图和视图解析器简介
- Spring 视图和视图解析器简介
- java并发编程(十三)--线程间协作:wait、notify、notifyAll
- java并发编程(十二)--可重入内置锁
- RxJava操作符(05-结合操作)
- RxJava操作符(05-结合操作)
- Eclipse开发经典教程之TreeViewer组件
- java并发编程(十一)--死锁
- java并发编程(十)--多线程环境中安全使用集合API
- java传递和返回对象
- 并发编程学习总结(五) :java 显式锁ReentrantLock使用详解之条件对象(2)
- java设计模式案例详解:观察者模式
- java并发编程(九)--并发编程中实现内存可见的两种方法比较:加锁和volatile变量
- Spring aop配置
- Eclipse中将项目导出jar包,以及转化成exe的方法
- 【2】Java并发编程:volatile关键字解析
- Spring整合Hessian服务
- JDK环境变量中dt.jar、tools.jar等变量值的作用