当前位置:七道奇文章资讯编程技术Java编程
日期: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供应了几个风趣且较为有效的办法,从下例便可看出:
//: 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 FancyToy相当复杂,因为它从Toy中担当,并实现了HasBatteries,Waterproof以及ShootsThings的接口.在main()中成立了一个Class句柄,并用位于呼应try块内的forName()初始化成FancyToy.
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 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]
所以操纵Class对象,我们几近能将一个对象的祖宗十八代都调查出来.
  以上是“java的rtti机制语法[Java编程]”的内容,如果你对以上该文章内容感兴趣,你可以看看七道奇为您推荐以下文章:
  • 利用Javascript实现网页水印(非图片水印)
  • Java开辟环境的搭建
  • Ubuntu java安装与配置
  • 办理Ubuntu 10.04 Firefox3.6 Java浏览器插件不工作的问
  • Ubuntu重装后Java环境的设置
  • Sun Java进入Ubuntu 10.10软件中央
  • Ubuntu 10.10配置Java开辟环境
  • 在Ubuntu 10.10中配置Java环境变量的办法
  • Ubuntu下Java环境的搭建
  • Ubuntu 10.04 下安装 Java, JRE
  • Ubuntu 10.04下的搭建SUN JAVA开辟环境
  • Ubuntu 12.04安装java7
  • 本文地址: 与您的QQ/BBS好友分享!
    • 好的评价 如果您觉得此文章好,就请您
        0%(0)
    • 差的评价 如果您觉得此文章差,就请您
        0%(0)

    文章评论评论内容只代表网友观点,与本站立场无关!

       评论摘要(共 0 条,得分 0 分,平均 0 分) 查看完整评论
    Copyright © 2020-2022 www.xiamiku.com. All Rights Reserved .