JAVA强大的基础功能JavaReflection
来源:优易学  2011-4-28 17:08:23   【优易学:中国教育考试门户网】   资料下载   IT书店

 

  4.获取构造器信息
  获取类构造器的用法与上述获取方法的用法类似,如:
  import java.lang.reflect.*;
  public class constructor1 {
  public constructor1() {
  }
  protected constructor1(int i, double d) {
  }
  public static void main(String args[]) {
  try {
  Class cls = Class.forName("constructor1");
  Constructor ctorlist[] = cls.getDeclaredConstructors();
  for (int i = 0; i < ctorlist.length; i++) {
  Constructor ct = ctorlist[i];
  System.out.println("name = " + ct.getName());
  System.out.println("decl class = " + ct.getDeclaringClass());
  Class pvec[] = ct.getParameterTypes();
  for (int j = 0; j < pvec.length; j++)
  System.out.println("param #" + j + " " + pvec[j]);
  Class evec[] = ct.getExceptionTypes();
  for (int j = 0; j < evec.length; j++)
  System.out.println("exc #" + j + " " + evec[j]);
  System.out.println("-----");
  }
  } catch (Throwable e) {
  System.err.println(e);
  }
  }
  }
  这个例子中没能获得返回类型的相关信息,那是因为构造器没有返回类型。
  这个程序运行的结果是:
  name = constructor1
  decl class = class constructor1
  -----
  name = constructor1
  decl class = class constructor1
  param #0 int
  param #1 double
  -----
  5.获取类的字段(域)
  找出一个类中定义了哪些数据字段也是可能的,下面的代码就在干这个事情:
  import java.lang.reflect.*;
  public class field1 {
  private double d;
  public static final int i = 37;
  String s = "testing";
  public static void main(String args[]) {
  try {
  Class cls = Class.forName("field1");
  Field fieldlist[] = cls.getDeclaredFields();
  for (int i = 0; i < fieldlist.length; i++) {
  Field fld = fieldlist[i];
  System.out.println("name = " + fld.getName());
  System.out.println("decl class = " + fld.getDeclaringClass());
  System.out.println("type = " + fld.getType());
  int mod = fld.getModifiers();
  System.out.println("modifiers = " + Modifier.toString(mod));
  System.out.println("-----");
  }
  } catch (Throwable e) {
  System.err.println(e);
  }
  }
  }
  这个例子和前面那个例子非常相似。例中使用了一个新东西 Modifier,它也是一个 reflection 类,用来描述字段成员的修饰语,如“private int”。这些修饰语自身由整数描述,而且使用 Modifier.toString 来返回以“官方”顺序排列的字符串描述 (如“static”在“final”之前)。这个程序的输出是:
  name = d
  decl class = class field1
  type = double
  modifiers = private
  -----
  name = i
  decl class = class field1
  type = int
  modifiers = public static final
  -----
  name = s
  decl class = class field1
  type = class java.lang.String
  modifiers =
  -----
  和获取方法的情况一下,获取字段的时候也可以只取得在当前类中申明了的字段信息 (getDeclaredFields),或者也可以取得父类中定义的字段 (getFields) 。
  6.根据方法的名称来执行方法
  文本到这里,所举的例子无一例外都与如何获取类的信息有关。我们也可以用 reflection 来做一些其它的事情,比如执行一个指定了名称的方法。下面的示例演示了这一操作:
  import java.lang.reflect.*;
  public class method2 {
  public int add(int a, int b) {
  return a + b;
  }
  public static void main(String args[]) {
  try {
  Class cls = Class.forName("method2");
  Class partypes[] = new Class[2];
  partypes[0] = Integer.TYPE;
  partypes[1] = Integer.TYPE;
  Method meth = cls.getMethod("add", partypes);
  method2 methobj = new method2();
  Object arglist[] = new Object[2];
  arglist[0] = new Integer(37);
  arglist[1] = new Integer(47);
  Object retobj = meth.invoke(methobj, arglist);
  Integer retval = (Integer) retobj;
  System.out.println(retval.intvalue());
  } catch (Throwable e) {
  System.err.println(e);
  }
  }
  }
  注:个人认为上面划线的粗体字最好用Object methobj = cls.newInstance();来代替,原因很明显如果这个类及方法事先都是清楚的也不需要用reflection了
  假如一个程序在执行的某处的时候才知道需要执行某个方法,这个方法的名称是在程序的运行过程中指定的 (例如,JavaBean 开发环境中就会做这样的事),那么上面的程序演示了如何做到。
  上例中,getMethod 用于查找一个具有两个整型参数且名为 add 的方法。找到该方法并创建了相应的 Method 对象之后,在正确的对象实例中执行它。执行该方法的时候,需要提供一个参数列表,这在上例中是分别包装了整数 37 和 47 的两个 Integer 对象。执行方法的返回的同样是一个 Integer 对象,它封装了返回值 84。

上一页  [1] [2] [3] 下一页

责任编辑:小草

文章搜索:
 相关文章
热点资讯
资讯快报
热门课程培训