8JAVA反射机制知识点

合集下载
  1. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
/** *本类用于测试反射 API,利用用户输入类的全路径, *找到该类所有的成员方法和成员属性 */ public class MyTest {
/** *构造方法 */ public MyTest(){
String classInfo=JOptionPane.showInputDialog(null,"输入类全路 径");//要求用户输入类的全路径
public static void main(String[] args) { try { //获得指定字符串类对象 Class cla=Class.forName("reflect.Tests"); //设置Class对象数组,用于指定构造方法类型 Class[] cl=new Class[]{int.class,int.class};
Java 的反射机制是在编译并不确定是哪个类被加载了,而是在程序运行的时 候才加载、探知、自审。使用在编译期并不知道的类。这样的特点就是反射。
那么 Java 反射有什么作用呢? 假如我们有两个程序员,一个程序员在写程序的时候,需要使用第二个程序
员所写的类,但第二个程序员并没完成他所写的类。那么第一个程序员的代码能 否通过编译呢?这是不能通过编译的。利用 Java 反射的机制,就可以让第一个 程序员在没有得到第二个程序员所写的类的时候,来完成自身代码的编译。
} } catch (ClassNotFoundException e) {
e.printStackTrace(); } } public static void main(String[] args) { new MyTest(); } }
运行的时候,我们输入 javax.swing.JFrame,那么运行结果如下:
息进行检测。当然这种检测在对运行的性能上会有些减弱,所以什么时候使用反 射,就要靠业务的需求、大小,以及经验的积累来决定。
那么如何利用反射 API 在运行的时候知道一个类的信息呢?
代码示例:
import java.lang.reflect.Field; import java.lang.reflect.Method; import javax.swing.JOptionPane;
}
System.out.println("********");
Field[] field=cla.getDeclaredFields();//利用得到的Class对象 的自审,返回属性对象集合
for(Field me:field){ //遍历该类属性的集合 System.out.println(me.toString());//打印属性信息
e.printStackTrace(); } }
}
class Tests{ public Tests(int x,int y){ System.out.println(x+" }
}
"+y);
运行的结果是” 33 67”。说明我们已经生成了 Tests 这个类的一个对象。
同样,也可以通过反射模式,来执行 Java 类的方法
使用反射机制的步骤: 导入 java.lang.relfect 包 遵循三个步骤
第一步是获得你想操作的类的 java.lang.Class 对象 第二步是调用诸如 getDeclaredMethods 的方法 第三步使用 反射 API 来操作这些信息
获得 Class 对象的方法
如果一个类的实例已经得到,你可以使用
try { Class cla=Class.forName(classInfo);//根据类的全路径进行类加
载,返回该类的Class对象
Method[] method=cla.getDeclaredMethods();//利用得到的Class 对象的自审,返回方法对象集合
for(Method me:method){//遍历该类方法的集合 System.out.println(me.toString());//打印方法信息
反射 API
反射 API 用于反应在当前 Java 虚拟机中的类、接口或者对象信息 功能 —获取一个对象的类信息. —获取一个类的访问修饰符、成员、方法、构造方法以及超类的信息. —检获属于一个接口的常量和方法声明. —创建一个直到程序运行期间才知道名字的类的实例. —获取并设置一个对象的成员,甚至这个成员的名字是 在程序运行期间才知道. —检测一个在运行期间才知道名字的对象的方法 利用 Java 反射机制我们可以很灵活的对已经加载到 Java 虚拟机当中的类信
//生成窗体类的实例 Object obj=cla.newInstance();
//获得窗体类的setSize方法对象,并指定该方法参数类型为int,int Method methodSize=cla.getMethod("setSize", new
Class[]{int.class,int.class});
public void javax.swing.JFrame.remove(java.awt.Component) public void javax.swing.JFrame.update(java.awt.Graphics) …………
******** public static final int javax.swing.JFrame.EXIT_ON_CLOSE private int javax.swing.JFrame.defaultCloseOperation
或者 Class c = Integer.TYPE;如果类名在编译期不知道, 但是在运行期
可以获得, 你可以使用下面的方法 Class c = Class.forName(strg); packagepublic class MyTest {
public static void main(String[] args) { TestOne one=null; try{ Class cla=Class.forName("com.TestOne");//进行com.TestOne类加
Java 的反射机制是 Java 特性之一,反射机制是构建框架技术的基础所在。灵活 掌握 Java 反射机制,对大家以后学习框架技术有很大的帮Fra Baidu bibliotek。
那么什么是 Java 的反射呢? 大家都知道,要让 Java 程序能够运行,那么就得让 Java 类要被 Java 虚拟机
加载。Java 类如果不被 Java 虚拟机加载,是不能正常运行的。现在我们运行的 所有的程序都是在编译期的时候就已经知道了你所需要的那个类的已经被加载 了。
Java 的反射机制它知道类的基本结构,这种对 Java 类结构探知的能力,我们 称为 Java 类的“自审”。大家都用过 Jcreator 和 eclipse。当我们构建出一个对象 的时候,去调用该对象的方法和属性的时候。一按点,编译工具就会自动的把该 对象能够使用的所有的方法和属性全部都列出来,供用户进行选择。这就是利用 了 Java 反射的原理,是对我们创建对象的探知、自审。
代码示例: package reflect;
import java.lang.reflect.Method;
/** * * 本类测试反射获得类的方法对象, * 并通过类对象和类方法对象,运行该方法 * */ public class MethodTest {
public static void main(String[] args) { try { //获得窗体类的Class对象 Class cla=Class.forName("javax.swing.JFrame");
//获得Constructor构造器对象。并指定构造方法类型 Constructor con=cla.getConstructor(cl);
//给传入参数赋初值 Object[] x={new Integer(33),new Integer(67)};
//得到实例
Object obj=con.newInstance(x); } catch (Exception e) {
【Class c = 对象
名.getClass(); 】
例: TextField t = new TextField(); Class c = t.getClass(); Class s = c.getSuperclass();
如果你在编译期知道类的名字,你可以使用如下的方法 Class c = java.awt.Button.class;
/* * 执行setSize()方法,并传入一个Object[]数组对象, * 作为该方法参数,等同于 窗体对象.setSize(300,300); */ methodSize.invoke(obj, new Object[]{new Integer(300),new Integer(300)});
TestOne对象的Class对象是否是同一个对象,在这里结果是true。说明如果两个 对象的类型相同,那么它们会有相同的Class对象
} }
class TestOne{ static{ System.out.println("静态代码块运行"); } TestOne(){ System.out.println("构造方法"); }
载,返回一个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());//比较两个
} 静态代码块运行 *********** 构造方法 构造方法
Class.forName("com.TestOne")的时候,实际上是对 com.TestOne 进行类加载,
这时候,会把静态属性、方法以及静态代码块都加载到内存中。所以这时候会打 印出"静态代码块运行"。但这时候,对象却还没有产生。所以"构造方法"这几个 字不会打印。当执行 cla.newInstance()的时候,就是利用反射机制将 Class 对 象生成一个该类的一个实例。这时候对象就产生了。所以打印"构造方法"。当执 行到 TestOne two=new TestOne()语句时,又生成了一个对象。但这时候类已经 加载完毕,静态的东西已经加载到内存中,而静态代码块只执行一次,所以不用 再去加载类,所以只会打印"构造方法",而"静态代码块运行"不会打印。
…………
大家可以发现,类的全路径是在程序运行的时候,由用户输入的。所以虚拟 机事先并不知道所要加载类的信息,这就是利用反射机制来对用户输入的类全路 径来对类自身的一个自审。从而探知该类所拥有的方法和属性。
通过上面代码,大家可以知道编译工具为什么能够一按点就能列出用户当前 对象的属性和方法了。它是先获得用户输入对象的字符串,然后利用反射原理来 对这样的类进行自审,从而列出该类的方法和属性。
反射机制不但可以例出该类对象所拥有的方法和属性,还可以获得该类的构造方 法及通过构造方法获得实例。也可以动态的调用这个实例的成员方法。
代码示例:
package reflect;
import java.lang.reflect.Constructor;
/** * * 本类测试反射获得类的构造器对象, * 并通过类构造器对象生成该类的实例 * */ public class ConstructorTest {
Class 类 要正确使用 Java 反射机制就得使用 java.lang.Class 这个类。它是 Java 反射机
制的起源。当一个类被加载以后,Java 虚拟机就会自动产生一个 Class 对象。通 过这个 Class 对象我们就能获得加载到虚拟机当中这个 Class 对象对应的方法、 成员以及构造方法的声明和定义等信息。
相关文档
最新文档