classloader双亲委托

1、加载的流程是:
(1)、loadClass是入口,首先判断是否以及加载过,class缓存机制(native方法,不清楚),如果已经加载过直接返回,否则进入下一步;
(2)、如果class没有被加载过,那么就查找当前classLoader的parent classLoader,如果不存在,使用系统加载器BootStrapClassLoader加载,
     如果parent classLoader存在,那么调用parent classLoader的loadClass的方法,parent classLoader 也执行相同的流程,这样就实现了双亲委托。
     此时如果parent classLoader 都加载不了,就会抛出ClassNotFoundException,然后捕获异常,不处理。
(3)、    此时将交由继承classLoader的子类不加载,使用findClass,但是classLoader抽象类里面实现是直接抛出ClassNotFoundException,
这里为了兼容1.2版本之前使用这种方式,现在推荐直接重写findClass,而不是重写loadClass,因为不能破坏双亲委托。
(4)、defineClass方法是JDK提供给开发的将字节数组转换为Class,是final的。
(5)、这里使用继承加组合的形式完成双亲委托,并且在loadClass里面使用了模板方法设计模式。

2、hotspot加载器的结构层次:
BootStrapClassLoader(系统) <- ExtClassLoader(扩展) <- AppClassLoader,其中ExtClassLoader与AppClassLoader都是sun.misc.Launcher的内部类,继承至URLClassLoader、SecureClassLoader、ClassLoader
在系统加载的时候初始化这两个加载器,然后将AppClassLoader的parent设置成ExtClassLoader。

3、Class.forName是执行加载、连接、初始化过程,ClassLoader.loadClass是执行加载、连接,连接是根据resolveClass方法的参数决定的。

你可能感兴趣的:(java,classloader)