有谁知道java反射机制原理的啊,最好能兴个例子,先谢谢了!^_^

解决方案 »

  1.   

    System.out.print(Class.forName("java.lang.String").newInstance().getClass().getName());
      

  2.   

    Java程序可以通过反射机制加载一个运行时才得知名称的class,获悉其完整构造,并生成其对象实体、或对其字段fields设值、或调用其方法methods。
      

  3.   

    运行时类型识别(Run-time Type Identification, RTTI)主要有两种方式,一种是我们在编译时和运行时已经知道了所有的类型,另外一种是功能强大的“反射”机制。要理解RTTI在Java中的工作原理,首先必须知道类型信息在运行时是如何表示的,这项工作是由“Class对象”完成的,它包含了与类有关的信息。类是程序的重要组成部分,每个类都有一个Class对象,每当编写并编译了一个新类就会产生一个Class对象,它被保存在一个同名的.class文件中。在运行时,当我们想生成这个类的对象时,运行这个程序的Java虚拟机(JVM)会确认这个类的Class对象是否已经加载,如果尚未加载,JVM就会根据类名查找.class文件,并将其载入,一旦这个类的Class对象被载入内存,它就被用来创建这个类的所有对象。一般的RTTI形式包括三种:1.传统的类型转换。如“(Apple)Fruit”,由RTTI确保类型转换的正确性,如果执行了一个错误的类型转换,就会抛出一个ClassCastException异常。2.通过Class对象来获取对象的类型。如Class c = Class.forName(“Apple”);Object o = c.newInstance();3.通过关键字instanceof或Class.isInstance()方法来确定对象是否属于某个特定类型的实例,准确的说,应该是instanceof / Class.isInstance()可以用来确定对象是否属于某个特定类及其所有基类的实例,这和equals() / ==不一样,它们用来比较两个对象是否属于同一个类的实例,没有考虑继承关系。 
    反射如果不知道某个对象的类型,可以通过RTTI来获取,但前提是这个类型在编译时必须已知,这样才能使用RTTI来识别。即在编译时,编译器必须知道所有通过RTTI来处理的类。使用反射机制可以不受这个限制,它主要应用于两种情况,第一个是“基于构件的编程”,在这种编程方式中,将使用某种基于快速应用开发(RAD)的应用构建工具来构建项目。这是现在最常见的可视化编程方法,通过代表不同组件的图标拖动到图板上来创建程序,然后设置构件的属性值来配置它们。这种配置要求构件都是可实例化的,并且要暴露其部分信息,使得程序员可以读取和设置构件的值。当处理GUI时间的构件时还必须暴露相关方法的细细,以便RAD环境帮助程序员覆盖这些处理事件的方法。在这里,就要用到反射的机制来检查可用的方法并返回方法名。Java通过JavaBeans提供了基于构件的编程架构。第二种情况,在运行时获取类的信息的另外一个动机,就是希望能够提供在跨网络的远程平台上创建和运行对象的能力。这被成为远程调用(RMI),它允许一个Java程序将对象分步在多台机器上,这种分步能力将帮助开发人员执行一些需要进行大量计算的任务,充分利用计算机资源,提高运行速度。Class支持反射,java.lang.reflect中包含了Field/Method/Constructor类,每个类都实现了Member接口。这些类型的对象都是由JVM在运行时创建的,用来表示未知类里对应的成员。如可以用Constructor类创建新的对象,用get()和set()方法读取和修改与Field对象关联的字段,用invoke()方法调用与Method对象关联的方法。同时,还可以调用getFields()、getMethods()、getConstructors()等方法来返回表示字段、方法以及构造器的对象数组。这样,未知的对象的类信息在运行时就能被完全确定下来,而在编译时不需要知道任何信息。另外,RTTI有时能解决效率问题。当程序中使用多态给程序的运行带来负担的时候,可以使用RTTI编写一段代码来提高效率。
      

  4.   

    我理解的反射就是可以偷人家藏好的东西(private之类的属性,方法),并且在逃跑的时候才告诉你(在运行时获取类的信息).
      

  5.   

       java语言编译完之后,并不是机器码,他还包含符号信息,虚拟机可以可以根据这些信息找到一个类,一个方法,等等。所有这就是为什么会有类反射的原因了。所以java api就可以提供类和方法让我们使用这个功能了。这也就是为什么过去的语言根本没有类反射的原因。
      

  6.   

    例子:http://www.360doc.com/showWeb/0/0/193230.aspx
      

  7.   

    动态的修改class文件,封装了ASM操作
      

  8.   

    import java.lang.reflect.*;
    public class ReflectionTest {
    public static void main(String[] args) {
    Class c=null;
    try {
    c=Class.forName("java.lang.String");
    System.out.println("package "+c.getPackage().getName()+";");
    System.out.print(Modifier.toString(c.getModifiers())+" ");
    System.out.print("class "+c.getSimpleName()+" ");
    if (c.getSuperclass()!=Object.class) {
    System.out.print("extends " + c.getSuperclass().getSimpleName());
    }
    Class[] inters=c.getInterfaces();
    if(inters.length>0){
    System.out.print("implements ");
    for(int i=0;i<inters.length;i++){
    System.out.print(inters[i].getSimpleName());
    if(i<inters.length-1){
    System.out.print(",");
    }
    }
    }
    System.out.println("{");
    printFields(c);
    printMethods(c);
    System.out.println("}");
    } catch (ClassNotFoundException e) {
    // TODO Auto-generated catch block
    e.printStackTrace();
    }

    }
    public static void printFields(Class c){
    Field[] field=c.getDeclaredFields();
    if(field.length>0){
    for(int i=0;i<field.length;i++){
    System.out.println(Modifier.toString(field[i].getModifiers())+" "+field[i].getType().getSimpleName()+" "+field[i].getName()+";");
    }
    }
    }
    public static void printMethods(Class c){
    Method[] method=c.getDeclaredMethods();
    if(method.length>0){
    for(int i=0;i<method.length;i++){
    Class[] parameter=method[i].getParameterTypes();
    System.out.print(Modifier.toString(method[i].getModifiers())+" "+method[i].getReturnType().getSimpleName()+" "+method[i].getName()+"(");
    for(int j=0;j<parameter.length;j++){
    System.out.print(parameter[j].getSimpleName()+" args");
    if(j!=parameter.length-1){
    System.out.print(",");
    }
    }
    System.out.print(") ");
    Class exception[]=method[i].getExceptionTypes();

    if (exception.length>0) {
    System.out.print("throws ");
    for (int j = 0; j < exception.length; j++) {
    System.out.print(exception[j].getSimpleName());
    }
    }
    System.out.println("{");
    System.out.println("\t... ...");
    System.out.println("}");
    }

    }
    }}代码是通过java反射探查出java.lang.String类的结构,希望对你有帮助,其实反射就是基因技术,Java反射机制主要提供了以下功能: 在运行时判断任意一个对象所属的类;在运行时构造任意一个类的对象;在运行时判断任意一个类所具有的成员变量和方法;在运行时调用任意一个对象的方法;生成动态代理。反射最大的应用就是框架
      

  9.   

    ....真是什么乱七八糟的说法都有
    1.反射跟ASM的动态创建 修改2进制文件根本不是一回事
    2.反射是java类在运行时对自己的一种描述
    3.通过反射你可以调用某个类的公共的属性和方法,前提是你必须要有这个类的实例 详见Methed类及其invoke()方法
      

  10.   

    听起来有点像逆向工程(reverse engineering)
      

  11.   

    这是我学反射的时候做的笔记,http://blog.csdn.net/zhuhichn/archive/2009/08/09/4427392.aspx楼主有什么问题可以联系我。这个注释不好,不过我现在的代码都有注释楼主需要可以给我要。
      

  12.   

    http://blog.csdn.net/wmh4242424cs/archive/2007/09/23/1796823.aspx
    这个可以参考