JAVA双亲委派机制
什么是双亲委派机制
java在类加载时有几种机制,其中一种就是双亲委派机制。
- 类加载器收到类加载的请求
- 将这个请求向上委托给父类加载器去完成,一直向上委托,直到启动类加载器。
- 启动加载器检查是否能够加载当前这个类,能加载就结束,使用当前的加载器,否则抛出异常,通知子加载器进行加载。
- 重复步骤3
白话文即,在类加载时,会一直向上委托,到根加载器(bootstrap),如果可以加载即加载,如果不可以,则抛出异常通知其子加载器加载,其子加载器递归执行。最后都加载不上,抛出Class Not Found
类加载器都有哪些
- 虚拟机自带的加载器
- 启动类加载器(根加载器) BootstrapClassLoader
- 扩展类加载器 ExtClassLoader 位置:C:\Program Files\Java\jre1.8.0_201\lib\ext
- 应用程序加载器 (应用程序加载器) AppClassLoader 位置:C:\Program Files\Java\jre1.8.0_201\lib\rt.jar
- 自定义加载器 实现rt.jar.java.lang.ClassLoader
源码 位置:rt.jar包下的java.lang.ClassLoader
protected Class<?> loadClass(String name, boolean resolve)
throws ClassNotFoundException
{
synchronized (getClassLoadingLock(name)) {
// First, check if the class has already been loaded
Class<?> c = findLoadedClass(name);
if (c == null) {
long t0 = System.nanoTime();
try {
if (parent != null) {
c = parent.loadClass(name, false);
} else {
c = findBootstrapClassOrNull(name);
}
} catch (ClassNotFoundException e) {
// ClassNotFoundException thrown if class not found
// from the non-null parent class loader
}
if (c == null) {
// If still not found, then invoke findClass in order
// to find the class.
long t1 = System.nanoTime();
c = findClass(name);
// this is the defining class loader; record the stats
sun.misc.PerfCounter.getParentDelegationTime().addTime(t1 - t0);
sun.misc.PerfCounter.getFindClassTime().addElapsedTimeFrom(t1);
sun.misc.PerfCounter.getFindClasses().increment();
}
}
if (resolve) {
resolveClass(c);
}
return c;
}
}
双亲委派的作用
保证核心.class安全,不允许被篡改。通过委托方式,向上面问一问,加载过了,就不用再加载一遍。保证数据安全