反射一些理解

 

java反射详解html


本身的一些理解:java

反射也能够理解为动态调用写了一个.java文件,编译后为字节码文件,虚拟机加载了这个字节码文件也就是加载到内存中,就能执行一些指令。在这个类中 当我须要调用另一个类的时候,而内存中并无这个类,这时候我就可使用反射动态加载这个类,使用其中的属性 跟方法。程序员

class.forName():就是至关于实现了一个IO操做,至关于把我须要的这个类经过IO操做加载到内存中,而后经过instance实例化这个对象,就能够得到对象的属性,方法。使用方法时,直接invoke()便可。不实例化对象也能够得到属性,方法。框架


Java的反射机制是Java特性之一,反射机制是构建框架技术的基础所在。灵活掌握Java反射机制,对你们之后学习框架技术有很大的帮助。eclipse

那么什么是Java的反射呢?工具

       你们都知道,要让Java程序可以运行,那么就得让Java类要被Java虚拟机加载。Java类若是不被Java虚拟机加载,是不能正常运行的。如今咱们运行的全部的程序都是在编译期的时候就已经知道了你所须要的那个类的已经被加载了。学习

Java的反射机制是在编译并不肯定是哪一个类被加载了,而是在程序运行的时候才加载、探知、自审。使用在编译期并不知道的类。这样的特色就是反射。spa

 

那么Java反射有什么做用呢?.net

假如咱们有两个程序员,一个程序员在写程序的时候,须要使用第二个程序员所写的类,但第二个程序员并没完成他所写的类。那么第一个程序员的代码可否经过编译呢?这是不能经过编译的。利用Java反射的机制,就可让第一个程序员在没有获得第二个程序员所写的类的时候,来完成自身代码的编译。htm

 

Java的反射机制它知道类的基本结构,这种对Java类结构探知的能力,咱们称为Java类的“自审”。你们都用过Jcreator和eclipse。当咱们构建出一个对象的时候,去调用该对象的方法和属性的时候。一按点,编译工具就会自动的把该对象可以使用的全部的方法和属性所有都列出来,供用户进行选择。这就是利用了Java反射的原理,是对咱们建立对象的探知、自审。

 

Class

       要正确使用Java反射机制就得使用java.lang.Class这个类。它是Java反射机制的起源。当一个类被加载之后,Java虚拟机就会自动产生一个Class对象。经过这个Class对象咱们就能得到加载到虚拟机当中这个Class对象对应的方法、成员以及构造方法的声明和定义等信息。

 

反射API

u反射API用于反应在当前Java虚拟机中的类、接口或者对象信息

u功能

获取一个对象的类信息.

  —获取一个类的访问修饰符、成员、方法、构造方法以及超类的信息.

  —检获属于一个接口的常量和方法声明.

  —建立一个直到程序运行期间才知道名字的类的实例.

  —获取并设置一个对象的成员,甚至这个成员的名字在程序运行期间才知道

  —检测一个在运行期间才知道名字的对象的方法


使用反射机制的步骤:

u导入java.lang.relfect 

u遵循三个步骤
第一步是得到你想操做的类的 java.lang.Class 对象
第二步是调用诸如 getDeclaredMethods 的方法
第三步使用 反射API 来操做这些信息 

得到Class对象的方法

u若是一个类的实例已经获得,你可使用

       Class c = 对象名.getClass(); 

      例: TextField t = new TextField();

              Class c = t.getClass();

              Class s = c.getSuperclass();

u若是你在编译期知道类的名字,你可使用以下的方法

Class c = java.awt.Button.class; 
或者

         Class c = Integer.TYPE;

u若是类名在编译期不知道可是在运行期能够得到你可使用下面的方法

          Class c = Class.forName(strg);

package

public class MyTest {

    public static void main(String[] args) {

       TestOne  one=null;

       try{

       Class  cla=Class.forName("com.TestOne");//进行com.TestOne类加载,返回一个Class对象

       System.out.println("********");

       one=(TestOne)cla.newInstance();//产生这个Class类对象的一个实例,调用该类无参的构造方法,做用等同于new TestOne()

       }catch(Exception e){

           e.printStackTrace();

       }

       TestOne two=new TestOne();

  System.out.println(one.getClass() == two.getClass());//比较两个TestOne对象的Class对象是不是同一个对象,在这里结果是true。说明若是两个对象的类型相同,那么它们会有相同的Class对象

    }

} 

class TestOne{

    static{

       System.out.println("静态代码块运行");

    }

    TestOne(){

       System.out.println("构造方法");

    }

}

静态代码块运行

***********

构造方法

构造方法

 

Class.forName("com.TestOne")的时候,其实是对com.TestOne进行类加载,这时候,会把静态属性、方法以及静态代码块都加载到内存中。因此这时候会打印出"静态代码块运行"。但这时候,对象却尚未产生。因此"构造方法"这几个字不会打印。当执行cla.newInstance()的时候,就是利用反射机制将Class对象生成一个该类的一个实例。这时候对象就产生了。因此打印"构造方法"。当执行到TestOne two=new TestOne()语句时,又生成了一个对象。但这时候类已经加载完毕,静态的东西已经加载到内存中,而静态代码块只执行一次,因此不用再去加载类,因此只会打印"构造方法",而"静态代码块运行"不会打印。

相关文章
相关标签/搜索