浅谈 java 反射机制

浅谈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.获取属性、方法、构造方法。

待更新…

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值