日期:2011-03-22 16:17:00 来源:本站整理
java的rtti机制语法[Java编程]
本文“java的rtti机制语法[Java编程]”是由七道奇为您精心收集,来源于网络转载,文章版权归文章作者所有,本站不对其观点以及内容做任何评价,请读者自行判断,以下是其具体内容:
Java用Class对象实现自己的RTTI功效——即便我们要做的只是象造型那样的一些工作.Class类也供应了其他大量方法,以便利我们利用RTTI.
首先必须得到指向得当Class对象的的一个句柄.就象前例演示的那样,一个办法是用一个字串以及Class.forName()办法.这是非常便利的,因为不需求那种范例的一个对象来获得Class句柄.但是,关于自己感爱好的范例,假如已有了它的一个对象,那么为了获得Class句柄,可调用属于Object根类一部份的一个办法:getClass().它的作用是返回一个特定的Class句柄,用来表示对象的实际范例.Class供应了几个风趣且较为有效的办法,从下例便可看出:
从中可以看出,class FancyToy相当复杂,因为它从Toy中担当,并实现了HasBatteries,Waterproof以及ShootsThings的接口.在main()中成立了一个Class句柄,并用位于呼应try块内的forName()初始化成FancyToy.//: ToyTest.java // Testing class Class interface HasBatteries {} interface Waterproof {} interface ShootsThings {} class Toy { // Comment out the following default // constructor to see // NoSuchMethodError from (*1*) Toy() {} Toy(int i) {} } class FancyToy extends Toy implements HasBatteries, Waterproof, ShootsThings { FancyToy() { super(1); } } public class ToyTest { public static void main(String[] args) { Class c = null; try { c = Class.forName("FancyToy"); } catch(ClassNotFoundException e) {} printInfo(c); Class[] faces = c.getInterfaces(); for(int i = 0; i < faces.length; i++) printInfo(faces[i]); Class cy = c.getSuperclass(); Object o = null; try { // Requires default constructor: o = cy.newInstance(); // (*1*) } catch(InstantiationException e) {} catch(IllegalAccessException e) {} printInfo(o.getClass()); } static void printInfo(Class cc) { System.out.println( "Class name: " + cc.getName() + " is interface? [" + cc.isInterface() + "]"); } } ///:~
Class.getInterfaces办法会返回Class对象的一个数组,用于表示包含在Class对象内的接口.
若有一个Class对象,也可以用getSuperclass()查询该对象的直接底子类是什么.当然,这种做会返回一个Class句柄,可用它作进一步的查询.这意味着在运行期的时刻,完好有机会调查到对象的完好层次构造.
若从表面看,Class的newInstance()办法仿佛是克隆(clone())一个对象的另一种手段.但二者是有辨别的.操纵newInstance(),我们可在没有现成对象供“克隆”的情形下新建一个对象.就象上面的程序演示的那样,当时没有Toy对象,只有cy——即y的Class对象的一个句柄.操纵它可以实现“虚拟构建器”.换言之,我们表达:“固然我不知道你的精确范例是什么,但请你无论若何都精确地成立自己.”在上述例子中,cy只是一个Class句柄,编译期间并不知道进一步的范例信息.一旦新建了一个实例后,可以得到Object句柄.但那个句柄指向一个Toy对象.当然,假如要将除Object可以接纳的其他任何消息发出去,首先必须举行一些调查研究,再举行造型.除此以外,用newInstance()成立的类必须有一个默许构建器.没有办法用newInstance()成立拥有非默许构建器的对象,所以在Java 1.0中大概存在一些限制.但是,Java 1.1的“反射”API(下一节谈论)却答应我们动态地利用类里的任何构建器.
程序中的最后一个办法是printInfo(),它获得一个Class句柄,通过getName()得到它的名字,并用interface()调查它是不是一个接口.
该程序的输出以下:
所以操纵Class对象,我们几近能将一个对象的祖宗十八代都调查出来.Class name: FancyToy is interface? [false] Class name: HasBatteries is interface? [true] Class name: Waterproof is interface? [true] Class name: ShootsThings is interface? [true] Class name: Toy is interface? [false]
以上是“java的rtti机制语法[Java编程]”的内容,如果你对以上该文章内容感兴趣,你可以看看七道奇为您推荐以下文章:
本文地址: | 与您的QQ/BBS好友分享! |
- ·上一篇文章:反射:运行期类信息
- ·下一篇文章:rtti在java造型前的查抄
- ·中查找“java的rtti机制语法”更多相关内容
- ·中查找“java的rtti机制语法”更多相关内容
评论内容只代表网友观点,与本站立场无关!
评论摘要(共 0 条,得分 0 分,平均 0 分)
查看完整评论