兑现RTTI的很多种方式(Java版本)

实现RTTI的很多种方式(Java版本)

一、Java中的RTTI种类:

 

 

     1 隐式的自动的上转型

     2 显式的强制的下转型

     3 instanceof

 

     额外的方式

     4 反射

 

二、RTTI的优点:

 

      在C++这样的程序设计语言中,做动态类型检查是一件非常危险的事情,可以说是一种hacked的行为。它只能使用一些强制类型转换的操作符来做一些类型转换,有可能引发对象切割(试你是否使用了对象之间的赋值操作符而定)。而且因为已经形成了机器码,所以没有办法做动态优化。

 

      Java因为在运行时还有一个虚拟机,所以可以动态地强制类型检查,虽然这种类型检查不如静态类型检查迅速,但是也很方便。

      比如,如果我们在程序中遇到一个对象,我们可以使用instanceof操作符判定它是否是某个对象,如果成功,可以立刻将他转型--不管是上转型还是下转型,虽然转型的过程中,引用会丢失具体类型,成为一个表面上有类型实际上是匿名类型的引用,但这仍然是一种类型安全的做法。即通过匿名基类的引用发现类型信息。如果在C++中这样做,就不知道会遇到怎么样的异常。

 

 

三、RTTI的缺点:

 

      表面上看起来,一个变量只能使用它引用类型的成员。但是实际上只要我们转型成功,则它可以使用任何被隐藏起来的成员。这就造成了意料之外的耦合。

 

      可行的解决方法有:

      1 将其他类型通过设置非public的包内类封装起来,让instanceof失败。

      2 通过内部私有类隐藏起来,让instanceof失败。

      3 通过匿名类隐藏起来,让instanceof失败。

 

      但是这通通难不倒反射。只要使用getClass()和其他get方法,可以得到一切成员,甚至只要setAccessible,连私有成员都可以得到。反射惟一做不到的就是,不能改变final成员。虚拟机将接受对于final的改变而不报任何异常但是不会做任何动作。