JAVA反射机制是在运行状态中,对于任意一个类,都能够知道这个类的所有属性和方法;对于任意一个对象,都能够调用它的任意方法和属性;这种动态获取信息以及动态调用对象方法的功能称为java语言的反射机制。
在日常开发过程中,会遇到某个类的某个成员变量、方法或是属性是私有的或是只对系统应用开放,这时候就可以利用Java的反射机制通过反射来获取所需的私有成员或是方法。比如JDBC链接:
Class.forName("com.mysql.cj.jdbc.Driver");
反射机制的相关类
Class代表类的实例,表示正在运行的Java应用程序中的类和接口。Class没有公共构造函数。相反,Class对象由Java虚拟机在加载类时自动构造,并通过调用类加载器中的defineClass方法来构造。
类名
public final class Class<T>
implements java.io.Serializable,
GenericDeclaration,
Type,
AnnotatedElement
在Class中有个静态代码块,此native方法表示向JVM注册本地方法。
private static native void registerNatives();
static {
registerNatives();
}
forName(String className)
@CallerSensitive
public static Class<?> forName(String className)
throws ClassNotFoundException {
//返回调用这个方法的类对象
Class<?> caller = Reflection.getCallerClass();
return forName0(className, true, ClassLoader.getClassLoader(caller), caller);
}
返回给定字符串名称的类或接口关联的类对象,@CallerSensitive为了防止通过构造双重反射来提升权限。
T newInstance()
@CallerSensitive
public T newInstance()
throws InstantiationException, IllegalAccessException
{
if (System.getSecurityManager() != null) {
//检查是否允许访问成员。如果拒绝访问,则抛出SecurityException
checkMemberAccess(Member.PUBLIC, Reflection.getCallerClass(), false);
}
// Constructor lookup
if (cachedConstructor == null) {
if (this == Class.class) {
throw new IllegalAccessException(
"Can not call newInstance() on the Class for java.lang.Class"
);
}
try {
Class<?>[] empty = {};
//先获得Constructor数组,拿到所有的构造,包括非public的
final Constructor<T> c = getConstructor0(empty, Member.DECLAR