反射机制:所谓的反射机制就是java语言在运行时拥有一项自观的能力。通过这种能力可以彻底的了解自身的情况为下一步的动作做准备。下面具体介绍一下java的反射机制。这里你将颠覆原来对java的理解。
Java的反射机制的实现要借助于4个类:class,Constructor,Field,Method;其中class代表的时类对 象,Constructor-类的构造器对象,Field-类的属性对象,Method-类的方法对象。通过这四个对象我们可以粗略的看到一个类的各个组 成部分。
Class:程序运行时,java运行时系统会对所有的对象进行运行时类型的处理。这项信息记录了每个对象所属的类,虚拟机通常使用运行时类型信息选择正 确的方法来执行(摘自:白皮书)。但是这些信息我们怎么得到啊,就要借助于class类对象了啊。在Object类中定义了getClass()方法。我 们可以通过这个方法获得指定对象的类对象。然后我们通过分析这个对象就可以得到我们要的信息了。
下面是段转自 nullpoint写的代码,便于自己理解
演示所需要的简单类
实现类
Java的反射机制的实现要借助于4个类:class,Constructor,Field,Method;其中class代表的时类对 象,Constructor-类的构造器对象,Field-类的属性对象,Method-类的方法对象。通过这四个对象我们可以粗略的看到一个类的各个组 成部分。
Class:程序运行时,java运行时系统会对所有的对象进行运行时类型的处理。这项信息记录了每个对象所属的类,虚拟机通常使用运行时类型信息选择正 确的方法来执行(摘自:白皮书)。但是这些信息我们怎么得到啊,就要借助于class类对象了啊。在Object类中定义了getClass()方法。我 们可以通过这个方法获得指定对象的类对象。然后我们通过分析这个对象就可以得到我们要的信息了。
下面是段转自 nullpoint写的代码,便于自己理解
演示所需要的简单类
class AA{ public AA(String name){ System.out.println(name); } public AA(int id,String name){ System.out.println(id+" "+name); } public int id; public String name; public int getId() { return id; } public void setId(int id) { this.id = id; } public String getName() { return name; } public void setName(String name) { this.name = name; } }
实现类
import java.lang.reflect.Constructor; import java.lang.reflect.Field; import java.lang.reflect.InvocationTargetException; import java.lang.reflect.Method; import java.lang.reflect.Modifier; public class MyReflection { /* * author nullpoint * 个人最近正在学习struts,hibernate框架,框架很多地方用到了反射,为更好的理解 * 自己研究了一下JAVA的反射机制,个人的一些代码仅供大家参考 */ public static void main(String[] args) { //定义需要反射的class文件的路径 String classPath = "com.cao.reflection.AA"; try { //通过下面的方法对class文件里的东西进行封装,可以在此基础上操作获得里面的类结构 Class<?> class1 = Class.forName(classPath); //获取所有的构造器 Constructor[] constructors = class1.getConstructors(); System.out.println("指定类的构造器的个数是:"+constructors.length); /* * 打印构造器的定义形式(参见下面定义的AA类里的两个构造器) * 结果是:public com.cao.reflection.AA(java.lang.String args0) public com.cao.reflection.AA(int args0,java.lang.String args1) */ for(Constructor<?> constructor:constructors){ //获得对应构造函数的参数类型 Class<?>[] ptype = constructor.getParameterTypes(); //获得构造函数的修饰符(modifier),getModfiers()返回的是int类型,需要通过Modifier类转换为相应的修饰符 System.out.print(Modifier.toString(constructor.getModifiers())+" "); //获得构造函数的名字 System.out.print(constructor.getName()+"("); for (int i = 0; i < ptype.length; i++) { //依次打印该构造函数所传递的参数 System.out.print(ptype[i].getName()+" args"+i); //控制','的输出 if(i<ptype.length-1){ System.out.print(","); } } System.out.print(")"); System.out.println(); } //还可以根据打印输出的构造函数结构,调用相应的含参的构造函数 Object obj = constructors[1].newInstance(1,"bird"); Field[] fields =class1.getDeclaredFields(); for(Field field:fields){ System.out.println(Modifier.toString(field.getModifiers())+" "+field.getType().getName()+" "+field.getName()); } //同样也可以通过class1.getDeclaredMethods()方法获取所有的方法,返回一个Method[] //获取指定的方法 Field field = class1.getDeclaredField("name"); //第一个参数为方法名,第二个是一个可变参数,为变量类型 Method method =class1.getDeclaredMethod("setName", field.getType()); //调用获得的方法,第一个参数为该class文件的一个实例,第二个参数为该方法需要的参数(可变参数) //这句话就相当于obj实例调用了他的一个method对应的方法 //因为我们不知道通过Class.forName(classPath).newInstance()方法实例中到底有什么方法 //只有通过这种方法对其里面的方法进行操作,struts框架填充form就是利用反射的这一点实现的 method.invoke(obj, "cat"); //调用完里面的对应方法后,我们就可以转型回来看看里面的东西了 AA aa = (AA) obj; System.out.println(aa.getName()); } catch (ClassNotFoundException e) { // TODO Auto-generated catch block e.printStackTrace(); } catch (IllegalArgumentException e) { // TODO Auto-generated catch block e.printStackTrace(); } catch (InstantiationException e) { // TODO Auto-generated catch block e.printStackTrace(); } catch (IllegalAccessException e) { // TODO Auto-generated catch block e.printStackTrace(); } catch (InvocationTargetException e) { // TODO Auto-generated catch block e.printStackTrace(); } catch (SecurityException e) { // TODO Auto-generated catch block e.printStackTrace(); } catch (NoSuchFieldException e) { // TODO Auto-generated catch block e.printStackTrace(); } catch (NoSuchMethodException e) { // TODO Auto-generated catch block e.printStackTrace(); } } }
发表评论
-
myeclipes8.6 反编译插件的安装
2011-04-13 11:25 914如下步骤是在网上找的但是有两个地方有问题: 1 jad的路径问 ... -
JVM的理解
2011-02-16 09:57 653躁动的绵羊的 《深入JVM概要》我觉得写的挺好 可以到他的博 ... -
JVM启动类加载器加载些什么
2011-02-14 10:20 784Bootstrap里加载的是<JAVA_RUNTIME_ ... -
使用异常机制的建议
2010-12-02 17:12 6851 异常处理不能代替简单测试 只在异常情况下使用异常机制 ... -
静态导入
2010-12-01 17:15 640import java.lang.System.*; 可以使用 ... -
初始化块
2010-12-01 16:17 5973种两种初始化数据域的方法: 1 在构造器中设置值 2 在声明 ... -
杂七杂八的记了些笔记 回头看看
2010-11-19 23:28 678经常听人 要向前看 现在我得回头看 -
Java 反射机制的补充(转自 凯旋人生)
2010-11-19 23:01 649Java的反射机制是运行时的环境。 Reflection是j ... -
系统基本业务流程
2010-11-19 14:51 709系统的基本业务流程: 在表示层中,首先通过JSP页面实现交互 ... -
ssh生命周期
2010-11-19 11:41 618... -
ssh 的简单认识
2010-11-19 10:47 711【转自 Java虫 】 Struts、spring、Hiber ... -
控制可见性的访问修饰符
2010-11-01 17:05 889private--仅对本类可见 public-- 对所有类可 ... -
final类和方法
2010-11-01 16:47 796有时候,可能希望阻止人们利用某个类来定义子类,不允许扩展的类被 ... -
类的设计技巧
2010-11-01 16:31 6961 将数据设计为私有 2 一定要将数据进行私有化 3 不要在类 ... -
静态块
2010-11-01 15:41 663public class NoMain { public ... -
默认域 初始化
2010-11-01 15:00 694如果在构造器中没有显示的给予域 赋初始化值,那么系统会自动的赋 ... -
参数调用
2010-11-01 14:40 675Java程序设计语言总是采用只调用。也就是说,方法得到的是所有 ... -
静态导入
2010-11-01 14:31 713静态导入 一般写法: public class Test { ... -
静态域 和 静态方法
2010-11-01 14:21 9741.静态域 如果将域定义 ... -
Final 实例域
2010-11-01 14:08 1074Final实例域可以将实例域定义为final。 构建对象时必须 ...
相关推荐
java反射机制java反射机制.zipjava反射机制.zipjava反射机制.zipjava反射机制.zipjava反射机制.zipjava反射机制.zipjava反射机制.zipjava反射机制.zipjava反射机制.zipjava反射机制.zipjava反射机制.zipjava反射机制...
JAVA反射机制应用 JAVA反射机制是JAVA语言中的一种动态机制,它能够在运行状态中,对于任意一个类,都能够知道这个类的所有属性和方法;对于任意一个对象,都能够调用它的任意一个方法。这种动态获取的信息以及动态...
Java反射机制是Java编程语言中的一个强大特性,它允许程序在运行时检查和操作类、接口、对象等的内部信息。通过Java反射机制,开发者可以在不知道具体类名的情况下创建对象,调用方法,访问和修改私有成员变量,以及...
Java反射机制是Java编程语言中的一个重要特性,它允许运行中的Java程序对自身进行检查并且可以直接操作程序的内部属性。在Java中,反射机制的核心类集中在java.lang.reflect包下,包括Class、Constructor、Method和...