引用变量的强制类型转换
为什么强制转换类型?
多太的弊端是不能使用子类特有的功能;用向下转型来解决这个问题,即把父类的引用强制转换为子类的引用。
格式
(转换的类型)要转换的对象
(type)variable
将variavle转换成type类型的变量
- 基本类型之间的转换只能在数值类型之间,这里所说的数值类型包括整数型、字符型和浮点型,不能和布尔类型相互转换。
- 引用类型之间的转换只能在具有继承关系的两个类型之间进行,如果是没有继承关系的类型,找这个对象必须实际上是子类实例才行即编译时类型是父类型,运行时类型是子类型,否则将会引发ClassCaseExpection异常。
实例:
Animal.class
package org.westos.pactice;
public class Animal {
int num=10;
String s="Father";
public void eat(){
System.out.println("动物要吃饭");
}
public void show(){
System.out.println("Animal中的show方法");
}
}
Cat.class
package org.westos.pactice;
public class Cat extends Animal {
int num=20;
String s="Son";
@Override
public void eat() {
System.out.println("猫爱吃鱼");
}
public void specialMethod(){
System.out.println("我是子类中特有的方法");
}
}
测试类中用父类的引用变量访问子类中特有的方法要转换类型
Animal an=new Cat();
//类型转换调用子类中的特有方法
((Cat) an).specialMethod();
把子类对象赋值给父类引用变量时,被称为向上转型,这类转型总是可以成功的,这种转型只是表明引用变量的编译时类型是父类,但实际上执行的是子类的方法时,依然表现出子类对象的行为方式。但是把父类对象赋值给子类的引用变量时,就需要有强制类型转换。
instanceof运算符
instanceof运算符的前一个操作数通常是一个引用类型变量,后一个操作数通常是一个类,它用于判断前面的对象是否是后面的类,或者其自雷、实现了的实例,如果是返回true否则返回false。
实例:
package org.westos.pactice;
public class Translate {
public static void main(String[] args) {
//声明hello时使用Object类,则hello的编译类型为Object
//hello变量实际的类型是String
Object hello="hello";
//String与Object存在继承关系
System.out.println("字符串是否是Object的实例:"+(hello instanceof Object));
//String是否是Object的实例:true
System.out.println("字符串是否是String的实例:"+(hello instanceof String));
//字符串是否是String的实例:true
}
}
instanceof的作用是:
在进行强制类型转换之前,首先判断前一个对象是否是后一个类的实例,是否可以转换成功,从而保证代码的健壮性。
注意ClassCastException 类型转换异常
如果第一个案例中添加一个Dog它也继承Animal;
在测试类中这样调用,会出现ClassCastException 类型转换异常,因为an现在指向Cat的对象,不能直接转换为Dog类型,他们两没有继承关系。
//类型转换调用子类中的特有方法
((Cat) an).specialMethod();
((Dog)an).specialMethod();
// Exception in thread "main" java.lang.ClassCastException: org.westos.pactice.Cat cannot be cast to org.westos.pactice.Dog
// at org.westos.pactice.Test01.main(Test01.java:36)
应该再将创建一个Dog对象并将an指向它,再做类型转换就Ok了。
((Cat) an).specialMethod();
an= new Dog();
((Dog)an).specialMethod();
//我是子类中特有的方法
//我是Dog类中的特有方法