双亲委派机制
-
类的加载是由类加载器完成的,类加载器包括:
根加载器( BootStrap )、扩展加载器( Extension )、系统加载器( System )和用户自定义类加载器( java.lang.ClassLoader 的子类)。从 Java 2 ( JDK 1.2 )开始,类加载过程采取了父亲委托机制( PDM )。 PDM 更好的保证了 Java 平台的安全性,在该机制中, JVM 自带的 Bootstrap 是根加载器,其他的加载器都有且仅有一个父类加载器。类的加载首先请求父类加载器加载,父类加载器无能为力时才由其子类加载器自行加载。 JVM 不会向 Java 程序提供对 Bootstrap 的引用。下面是关于几个类加载器的说明: -
Bootstrap :一般用本地代码实现,负责加载 JVM 基础核心类库( rt.jar );
-
Extension :从 java.ext.dirs 系统属性所指定的目录中加载类库,它的父加载器是 Bootstrap ;
-
system class loader :又叫应用类加载器,其父类是 Extension 。它是应用最广泛的类加载器。它从环境变量 classpath 或者系统属性 java.class.path 所指定的目录中记载类,是用户自定义加载器的默认父加载器。
-
用户自定义类加载器: java.lang.ClassLoader 的子类
双亲委派机制是可以修改的,有些服务器就是自定义类加载器优先的
ClassLoader分为:
-
Bootstrap classLoader主要负责加载核心的类库(java.lang.*等),构造ExtClassLoader和APPClassLoader;
-
ExtClassLoader;主要负责加载jre/lib/ext目录下的一些扩展jar
-
AppClassLoader:主要负责加载应用程序的主函数类
-
Bootstrap classLoader 由于引导类加载器涉及到虚拟机本地实现细节,开发者无法直接获取到启动类加载器的引用,所以不允许直接通过引用进行操作
-
CustomClassLoader,用户自定义的类加载器,可加载指定路径的
class
文件 -
下图代表双亲委派机制的加载过程
意为,首先从自己编写的类加载器,一次往上逐步判断,是否有加载过,加载过即以及加载过,结束;没有则继续向上传递,直到达到最大的父类加载器BootstrapClassLoader都没有加载过,然后从上往下,逐步判断自己的职能能否加载该.class文件,不行就往下,可以就加载,直到用户自己写的类加载器,还是不能,便会报异常,告诉你找不到。至此整个流程图的内容都在这里了。
- 双亲委派机制的优点
- 重复的类不重复加载,节约了内存,提高资源利用率
- 系统已经加载过的.class文件就会处于安全状态,应为已经加载过,类加载器不会在加载,所以想要篡改系统的.class文件在双亲委派机制下,无法成功。提高了系统的安全性
。