双亲委派机制和沙箱安全机制

双亲委派机制和沙箱安全机制

如果对类加载器没有了解的可以先看我另一篇文章讲得是类加载器点击传送

概述

为什么需要双亲委派机制和沙箱安全机制,举个栗子,如果说我们任何人都可以在项目里去定义一个java.lang包下的String类进行使用的话,就说明java核心的API可以被随意篡改。这样即不安全,也不规范了。

双亲委派机制

工作原理:

如果一个类加载器收到了类加载请求,它并不会自己先去加载,而是把这个请求委托给自己的父类加载器去执行,如果父类加载器存在父类则进一步向上进行委托,依次递归,最终到达顶层启动类加载器。 如果父类加载器可以完成类加载任务,就成功返回。反之,子加载器才会尝试自己去加载,这就是双亲委派模式

沙箱安全机制

自定义String类,但在加载自定义String类的时候会先使用引导类加载器加载,而引导类加载器在加载的过程中会先加载jdk自带的文件,报错说没有main方法,就是因为加载的是rt.jar包中的String,这样就可以保证对加载核心源代码的保护,这就是沙箱安全机制

其他

所以在虚拟机中判断两个对象是否为同一个类的两个条件

  • 类的完整类名是否一致
  • 加载这个类的ClassLoader(类加载器)是否相同。

小结

双亲委派机制和沙箱安全机制都是为了保护核心源代码的安全,并且保证所有的类只能被加载一次。

秃头萌新一枚 多多关照

你可能感兴趣的:(java内存分配和垃圾回收,java,jvm)