双亲委派模型是Java加载类的机制.采用双亲委派模型的好处是Java类随着它的类加载器一起具备了一种带有优先级的层级关系,通过这种层级关系可以避免类的重复加载.
Bootstrap ClassLoader(启动类加载器): 负责将%JAVA_HOME%/lib目录中或Xbootclasspath中参数指定的路径中的,并且是虚拟机识别的(按名称)类库加载到JVM中
Extension ClassLoader(扩展类加载器): 负责加载%JAVA_HOME%/lib/ext中的所有类库
Application ClassLoader(应用程序加载器): 负责ClassPath中的类库
概述:
双亲委派模式的工作原理的是;如果一个类加载器收到了类加载请求,它并不会自己先去加载,而是把这个请求委托给父类的加载器去执行,如果父类加载器还存在其父类加载器,则进一步向上委托,依次递归,请求最终将到达顶层的启动类加载器,如果父类加载器可以完成类加载任务,就成功返回,倘若父类加载器无法完成此加载任务,子加载器才会尝试自己去加载,这就是双亲委派模式,即每个儿子都不愿意干活,每次有活就丢给父亲去干,直到父亲说这件事我也干不了时,儿子自己想办法去完成
解决问题:
1.双亲委派模型是Java加载类的机制.采用双亲委派模型的好处是Java类随着它的类加载器一起具备了一种带有优先级的层级关系,通过这种层级关系可以避免类的重复加载.
2.其次是考虑到安全因素,java核心api中定义类型不会被随意替换,假设通过网络传递一个为java.lang.Integer的类,通过双亲委托模式传递到启动类加载器,而启动类加载器在核心Java API发现这个名字的类,发现该类已被加载,并不会重新加载网络传递的过来的java.lang.Integer,而直接返回已加载过的Integer.class,这样便可以防止核心API库被随意篡改。
例子:

ClassLoader

测试

结果:

这里的执行逻辑是 类加载器得到这个加载请求 会先去 自己的父类加载器 去找 如果没有继续向上走 有就执行 没有再去 子类加载器 再去加载 最终还没有通过 IO流 写入到byte文件中 最终通过自定义的类加载器 进行加载
1053

被折叠的 条评论
为什么被折叠?



