当前位置:天才代写 > tutorial > JAVA 教程 > java的rtti机制语法

java的rtti机制语法

2017-11-13 08:00 星期一 所属: JAVA 教程 浏览:399

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工具,我们险些能将一个工具的祖宗十八代都观测出来。

 

    关键字:

天才代写-代写联系方式