浅谈java 反射机制
一、RTTI与反射
都可以在运行时识别对象和类的信息
RTTI:(Run-Time Type Identification 运行时类型设别)可以告诉你某个对象的确切类型。但是有一个限制:在编译时,编译器必须要知道所有通过RTTI来处理的类。
对于一个简单的程序来说,这似乎不是限制,但是假设当你获取了某一个不在你程序空间中的 对象的 引用,事实上,在编译时你的程序根本没法知道这个对象是哪一个类的,并且这个类很有可能在编译你的代码程序之后很久才会出现,那如何去使用这种类呢?
反射 :提供了一种机制——用来检查可用的方法,并返回方法名,获取类的信息。动机是希望能在跨网络的远程平台上能够创建和运行对象。
重要的是,当通过反射与一个未知类型的类打交道时,JVM只是简单的检查这个对象,看它属于哪一个特定类型的类,在用它做任何事情之前必须先加载那个类的class对象。
反射与RTTI的区别: 对RTTI来说,编译器在编译时打开和检查 .class文件,而对于反射机制来说 .class文件在编译时是不可获取的,所以是在运行时打开和检查.class文件。
运行时:.class文件被JVM装载运行(这里真正运行着我们所写的代码)的过程。(我们在编译器上写的是 .java文件,通过javac编译变成.class文件)
—**
一、sun为提供的 反射机制中的类
java.lang.Class;
java.lang.reflect.Constructor;
java.lang.reflect.Field;
java.lang.reflect.Method;
java.lang.reflect.Modifier;
二、反射机制的基本使用
1.获取class
//第一种方法:Object-->getClass(),该方法需要先创建对象,不过已经有了对象,还拿反射机制干嘛用呢?
String s = new String();
Class c = s.getClass();
//第二种方法:任何数据类型(包括基本的数据类型)都有一个“静态”的class属性,该方法需要导入类包 依赖性太强
Class stuClass2 = Student.class;
//第三种方法:通过class类的静态方法:forName(String className)
try {
Class.forName(className);
} catch (ClassNotFoundException e) {
System.out.println("this class doesn't exist!");
}//注意捕捉异常
2.创建对象
(获取类之后可创建其对象)
利用 newInstance()方法
先通过Class对象获取指定的Constructor对象,再调用Constructor对象的newInstance()方法来创建对象,这种方法可以用指定的构造器构造类的实例。
newInstance()方法:public T newInstance()
throws InstantiationException,
IllegalAccessException
例如:
Class c =Class.forName("Student"); //创建此Class 对象所表示的类的一个新实例
Objecto = c.newInstance(); //调用了Student的无参数构造方法
3.判断是否为某个类的实例
public boolean isInstance(Object obj)
obj - 要检查的对象
如果 obj是这个类的一个实例,则为true
4.获取属性、方法、构造方法。
待更新…