反射机制
通过Java的反射机制可以 *** 作字节码文件。
优点类似与黑客。
通过反射机制可以 *** 作代码片段。(class文件)
反射机制的相关类在java.lang.reflect.*;包下
反射机制相关的几个重要的类:
·java.lang.class;代表整个字节码文件,一个类型。
·java.lang.reflect.Method;代表字节码中的方法字节码。
·java.lang.reflect.Constructor;代表字节码中的构造方法字节码。
·java.lang.reflect.Field;代表字节码中的属性字节码。
获取Class的三种方式
一.Class.forName()
1.静态方法
2.方法的参数是一个字符串
3.字符串需要的是一个完整的类名
4.完整类名必须带有包名。java.lang包也不能省略
语法:Class c = Class.forName(“完整类名带包名”);
二.Class c = 对象.getClass();
package com.exception.test; import java.io.*; import java.nio.charset.StandardCharsets; import java.util.*; public class test { public static void main(String[] args) { Class c1= null; try { c1 =Class.forName("java.lang.String"); //c1代表String.class文件,或者说C1代表String类型。 Class c2=Class.forName("java.util.Date"); //c2代表Date类型。 Class c3=Class.forName("java.lang.Integer"); //c3代表Integer类型 Class c4=Class.forName("java.lang.System"); //c4代表System类型 } catch (ClassNotFoundException e) { e.printStackTrace(); } String s = "abd"; Class s1 = s.getClass(); System.out.println(s1==c1); } }
返回结果为true,分析内存如图下所示:
三.Java语言中任何一种类型,包括基本数据类型,它都有.class属性。
语法 Class c =任何类型.class;
Class z =String.class; Class k =Date.class; Class f =int.class; Class e =double.class;
不使用反射机制和使用反射机制(通过Class的newInstance方法来实例化对象,内部实际上调用了无参数构造方法,必须保证无参数构造存在才行)分别创建对象:
反射机制可以访问class文件,让程序更加灵活。
如果只想要一个类中的静态代码块执行,其他代码一律不执行
可以采用Class.forName(“完整类名”);的方式
这个方法的执行会导致类加载,类加载时静态代码块执行。JDBC技术时会使用。
通用的编写路径方式(文件放在类路径下时可以src下的都是类路径):
Thread.currentThread()是当前线程对象
getContextClassLoader()是线程对象的方法,可以获取到当前线程的类加载器对象
getResource()这是类加载器对象的方法,当前线程的类加载器默认从类的根路径下加载资源
**String path = Thread.currentThread().getContextClassLoader().getResource("").getpath();**获取绝对路径
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)