</pre><p></p><p>RTTI(RunTimeType Identification,运行时类型识别):在运行时,识别一个对象的类型。</p>首先举个例子,一个父亲有三个儿子,父亲和儿子之间存在继承关系:儿子的老家都是父亲的老家。
abstract class 老子 {
<span style="white-space:pre"> </span>void 家在哪里() {
System.out.println(this + "家在鹿邑");
}
abstract public String toString();
}
class 大儿子 extends 老子 {
@Override
public String toString() {
// TODO Auto-generated method stub
return "大儿子";
}
}
class 二儿子 extends 老子 {
@Override
public String toString() {
// TODO Auto-generated method stub
return "二儿子";
}
}<pre name="code" class="java">class 三儿子 extends 老子 {
@Override
public String toString() {
// TODO Auto-generated method stub
return "三儿子";
}
}
public class Shapes {
public static void main(String[] args) {
List<老子> 父子 = Arrays.asList(new 大儿子(), new 二儿子(), new 三儿子());
for (老子 shape : 父子)
shape.家在哪里();
}
}
抽象方法只在抽象类中才有意义。且该类的子类必须覆盖父类的抽象方法,否则报错。 tostring方法:当对象与string对象用" + "连接时,必须对象自动调用toString方法,toString方法的返回值与string对象相连接。
把老子对象放入list<老子>数组中时,会发生向上转型。但大儿子、二儿子和三儿子在向上转型时会丢失老子对象的具体类型,对于数组而言,他们只是老子类的对象。
实际上RTTI类型转换并不能彻底,object被转型为老子,而不是转型为儿子,这是因为目前我们只知道list<老子>保存的都是老子,在编译时,将由容器和java的泛型系统来强制确保这一点,而在运行时,由类型转换操作来确保这一点。