动态装载
一 程序运行的过程
二 classLoader类加载机制
1 并非一次性加载
2 需要的时候加载即运行期间动态加载
3 static语句块在加载后执行一次
4 dynamic语句块每次new新的对象都会执行(等同与构造方法中的语句,少用)
说明:
1,2点是说程序在加载类时,并不是一次性把所有用到的类都加载进去,而是运行到哪里就加载到哪里,是动态的。
三JDK中classloader的分类
classLoader具体来说有四个
bootstrap classloader 负责核心类的加载
extension classloader 负责扩展类的加载
application classloader 负责自定义类的加载
other classloader
说明:
bootstrap classloader和extension classloader由c或汇编语言或c++操作系统本地语言写的。其他的classloader是用java写的。所以其他的classloader也需要由loader进来
四JDK中classloader的层次关系
如图:
classloader存在着层次关系,但不是继承。一个classloader要load class时会向上一层报告,查看是否已经load,如果load了就不会再次load。
反射机制
什么是反射?
反射机制就是我们可以通过反射的API接口可以探索运行期间的一个class的内部结构,并且根据他的内部结构来决定方法怎么样调用。
反射机制的核心类
类加载到内存中后就是一个个对象,其方法,属性等等也可以看作是一个对象。
class 类的类型对象,即每个类都有这样的一个属性表示类型。例如:Object.getClass()就可以得到该类的对象,相当于类名.class。
constructor 代表类中的构造方法
field 代表类中的成员变量
method 代表类中的方法
modifier 代表类中的修饰符
这几个类就是我们实现反射机制的关键,首先我们要通过class.forName("XXX")得到加载到内存中XXX的class对象,然后再得到他的方法,成员变量来调用对象的方法。
实现反射的核心代码
package Reflect;
import java.lang.reflect.Field;
import java.lang.reflect.Method;
public class Reflect {
public Object invokeTest(String className,String fieldName,Object args){
Object obj=null;
try {
//得到内存中的class对象
Class<?> classObj=Class.forName(className);
//将class对象示例出来
obj=classObj.newInstance();
//得到指定的属性对象
Field field=classObj.getDeclaredField(fieldName);
//拼接处要调用的方法名称
String methodName="set"+fieldName.substring(0,1).toUpperCase()+fieldName.substring(1);
//得到指定的方法对象
Method method= classObj.getDeclaredMethod(methodName,field.getType());
//调用该方法
method.invoke(obj, args);
} catch (Exception e) {
e.printStackTrace();
}
return obj;
}
}