主要讨论的是非基本数据类型,即class类型之间的转换。我们知道,子类向父类的转换毫无疑问是可以顺利完成的(因为父类中的成员变量子类一定有)。但有时候为了使用多态性,需要将父类对象的句柄强制转换为子类的对象(强制造型),由于子类的成员可能在父类中没有,这时可能就会出现问题。
假设有以下两个类father和kid:
class father{
int a;
public father(int k) { //构造函数
this.a=k;
}
}
class kid extends father{
int b;
public kid(int k) { //构造函数
super(k);
b=2*k;
}
public int getB() {
return this.b;
}
}
如果这样对引用f1做类型转换
public static void main(String[] args) {
father f1= new father(5);
kid k=(kid)f1;
System.out.println(k.getB());
}
编译不会出问题而运行会抛出异常,提示father cannot be cast to kid。
但修改一下主函数部分的类型转换方式:
public static void main(String[] args) {
kid k1=new kid(10);
father f1=(father)k1;
kid k=(kid)f1;
System.out.println(k.getB());
}
输出结果
20
可见,变量f1本身就是子类的对象,由于一些原因暂时被转换为父类的对象引用了,但子类特有的数据部分并没有丢失,因此重新转换为子类对象时,可以顺利的访问子类特有的函数和成员变量。而前一个程序中,只是单纯想将父类对象转换为子类,显然是不行的。而这个问题编译时不会被发现。