`
primer_2004
  • 浏览: 127965 次
  • 性别: Icon_minigender_1
  • 来自: 广州
社区版块
存档分类
最新评论

候捷谈Java反射机制(3)

    博客分类:
  • Java
阅读更多

Java Reflection API 运用示例<o:p></o:p>

5示范4提过的每一个Reflection API,及其执行结果。程序中出现的tName()是个辅助函数,可将其第一自变量所代表的Java class完整路径字符串剥除路径部分,留下class名称,储存到第二自变量所代表的一个hashtable去并返回(如果第二自变量为null,就不储存而只是返回)。<o:p></o:p>

<o:p> </o:p>

#001 Class c = null;<o:p></o:p>

#<st1:chmetcnv w:st="on" tcsc="0" numbertype="1" negative="False" hasspace="True" sourcevalue="2" unitname="C">002 c</st1:chmetcnv> = Class.forName(args[0]);<o:p></o:p>

#003<o:p></o:p>

#004 Package p;<o:p></o:p>

#005 p = c.getPackage();<o:p></o:p>

#006<o:p></o:p>

#007 if (p != null)<o:p></o:p>

#008    System.out.println("package "+p.getName()+";");<o:p></o:p>

<o:p> </o:p>

执行结果(例):<o:p></o:p>

package java.util;<o:p></o:p>

5-1:找出class 隶属的package。其中的c将继续沿用于以下各程序片段。<o:p></o:p>

<o:p> </o:p>

#001 ff = c.getDeclaredFields();<o:p></o:p>

#002 for (int i = 0; i < ff.length; i++)<o:p></o:p>

#003    x = tName(ff[i].getType().getName(), classRef);<o:p></o:p>

#004<o:p></o:p>

#005 cn = c.getDeclaredConstructors();<o:p></o:p>

#006 for (int i = 0; i < cn.length; i++) {<o:p></o:p>

#007    Class cx[] = cn[i].getParameterTypes();<o:p></o:p>

#008    for (int j = 0; j < cx.length; j++)<o:p></o:p>

#009        x = tName(cx[j].getName(), classRef);<o:p></o:p>

#010 }<o:p></o:p>

#011<o:p></o:p>

#<st1:chmetcnv w:st="on" tcsc="0" numbertype="1" negative="False" hasspace="True" sourcevalue="12" unitname="mm">012 mm</st1:chmetcnv> = c.getDeclaredMethods();<o:p></o:p>

#013 for (int i = 0; i < mm.length; i++) {<o:p></o:p>

#014    x = tName(mm[i].getReturnType().getName(), classRef);<o:p></o:p>

#015    Class cx[] = mm[i].getParameterTypes();<o:p></o:p>

#016    for (int j = 0; j < cx.length; j++)<o:p></o:p>

#017        x = tName(cx[j].getName(), classRef);<o:p></o:p>

#018 }<o:p></o:p>

#019 classRef.remove(c.getName()); //不必记录自己(不需import 自己)<o:p></o:p>

<o:p> </o:p>

执行结果(例):<o:p></o:p>

import java.util.ListIterator;<o:p></o:p>

import java.lang.Object;<o:p></o:p>

import java.util.LinkedList$Entry;<o:p></o:p>

import java.util.Collection;<o:p></o:p>

import java.io.ObjectOutputStream;<o:p></o:p>

import java.io.ObjectInputStream;<o:p></o:p>

5-2:找出导入的classes,动作细节详见内文说明。<o:p></o:p>

<o:p> </o:p>

#001 int mod = c.getModifiers();<o:p></o:p>

#002 System.out.print(Modifier.toString(mod)); //整个modifier<o:p></o:p>

#003<o:p></o:p>

#004 if (Modifier.isInterface(mod))<o:p></o:p>

#005    System.out.print(" "); //关键词 "interface" 已含于modifier<o:p></o:p>

#006 else<o:p></o:p>

#007    System.out.print(" class "); //关键词 "class"<o:p></o:p>

#008 System.out.print(tName(c.getName(), null)); //class 名称<o:p></o:p>

<o:p> </o:p>

执行结果(例):<o:p></o:p>

public class LinkedList<o:p></o:p>

5-3:找出classinterface 的名称,及其属性(modifiers)。<o:p></o:p>

<o:p> </o:p>

#001 TypeVariable<Class>[] tv;<o:p></o:p>

#002 tv = c.getTypeParameters(); //warning: unchecked conversion<o:p></o:p>

#003 for (int i = 0; i < tv.length; i++) {<o:p></o:p>

#004    x = tName(tv[i].getName(), null); //例如 E,K,V...<o:p></o:p>

#005    if (i == 0) //第一个<o:p></o:p>

#006        System.out.print("<" + x);<o:p></o:p>

#007    else //非第一个<o:p></o:p>

#008        System.out.print("," + x);<o:p></o:p>

#009    if (i == tv.length-1) //最后一个<o:p></o:p>

#010        System.out.println(">");<o:p></o:p>

#011 }<o:p></o:p>

<o:p> </o:p>

执行结果(例):<o:p></o:p>

public abstract interface Map<K,V><o:p></o:p>

public class LinkedList<E><o:p></o:p>

5-4:找出parameterized types 的名称<o:p></o:p>

<o:p> </o:p>

#001 Class supClass;<o:p></o:p>

#002 supClass = c.getSuperclass();<o:p></o:p>

#003 if (supClass != null) //如果有super class<o:p></o:p>

#004    System.out.print(" extends" +<o:p></o:p>

#005 tName(supClass.getName(),classRef));<o:p></o:p>

<o:p> </o:p>

执行结果(例):<o:p></o:p>

public class LinkedList<E><o:p></o:p>

extends AbstractSequentialList,<o:p></o:p>

5-5:找出base class。执行结果多出一个不该有的逗号于尾端。此非本处重点,为简化计,不多做处理。<o:p></o:p>

<o:p> </o:p>

#001 Class cc[];<o:p></o:p>

#002 Class ctmp;<o:p></o:p>

#003 //找出所有被实现的interfaces<o:p></o:p>

#004 cc = c.getInterfaces();<o:p></o:p>

#005 if (cc.length != 0)<o:p></o:p>

#006    System.out.print(", \r\n" + " implements "); //关键词<o:p></o:p>

#007 for (Class cite : cc) //JDK1.5 新式循环写法<o:p></o:p>

#008    System.out.print(tName(cite.getName(), null)+", ");<o:p></o:p>

<o:p> </o:p>

执行结果(例):<o:p></o:p>

public class LinkedList<E><o:p></o:p>

extends AbstractSequentialList,<o:p></o:p>

implements List, Queue, Cloneable, Serializable,<o:p></o:p>

5-6:找出implemented interfaces。执行结果多出一个不该有的逗号于尾端。此非本处重点,为简化计,不多做处理。<o:p></o:p>

分享到:
评论

相关推荐

    候捷谈Java反射机制

    Java反射机制是Java编程语言中的一个重要特性,它允许程序在运行时获取和操作任何已知名称的类的内部信息。这一机制使得Java具备了一定的动态性,虽然在传统的分类中Java被视为静态类型语言。通过反射,开发者可以在...

    候捷的java精髓

    7. **反射机制**:深入理解Java反射的概念,如何在运行时动态访问类、接口、方法和构造器。 8. **设计模式**:讲解常用的设计模式,如单例、工厂、观察者、装饰者、代理等,以及如何在实际开发中应用。 9. **JVM...

    反射机制

    这篇《候捷谈Java反射机制》的文章应该深入探讨了这一主题。 反射的核心概念主要包括Class类、Constructor类、Method类和Field类。以下是对这些关键知识点的详细说明: 1. **Class类**:在Java中,每个类都有一个...

    侯捷-Java编程思想+第2版(繁体版)

    - **异常处理**:详细讲解Java中的异常处理机制,包括异常的抛出、捕获及处理策略,帮助开发者编写健壮的应用程序。 - **泛型与集合框架**:重点介绍了Java泛型的概念及其在集合框架中的应用,使开发者能够写出类型...

    北京金卫捷科技发展有限公司Java笔试题

    7. **反射机制**:利用反射动态获取类的信息,创建对象,调用方法,修改字段值,了解Class类和Method类的使用。 8. **设计模式**:常见的设计模式如工厂模式、单例模式、观察者模式、装饰者模式等,理解其应用场景...

    Practical Java一书及代码

    8. **反射与动态代理**:Java的反射机制能让我们在运行时检查类的信息并操作对象,动态代理则能在运行时创建具有特定接口的代理类,这对于AOP(面向切面编程)和插件式系统很有用。 9. **Java EE基础**:虽然不是...

    Android程序员简历最新版

    2. **Java技术**:精通Java核心技术,包括反射、集合、网络编程和IO流的使用。 3. **Web应用开发**:熟练运用jsp、servlet、JSTL/EL、dom4j和JDBC,具备Struts2、Spring、Hibernate等主流框架的实践经验。 4. **...

Global site tag (gtag.js) - Google Analytics