JVM类装载器:是什么?有哪几种?双亲委派机制和沙箱安全是什么?
类装载器ClassLoader
是什么?
负责加载并初始化.class文件,class文件在文件开头有特定的文件标识,将class文件字节码内容加载到内存中,并将这些内容转换成方法区中运行时数据结构。ClassLoader只负责.class文件的加载,至于它是否可以运行,则由Execution Engine执行引擎决定。
类装载器有几种?(3+1)
- 虚拟机器自带的加载器
- Bootstrap Class Loader 启动类(根)加载器 /jre/lib/rt.jar
- Extension Class Loader 扩展类加载器 /jre/lib/ext/*.jar
- Application Class Loader 应用程序加载器 CLASSPATH
- 用户自定义的类加载器
- User-Defined Class Loader 用户自定义的类加载器
什么是双亲委派机制?
当一个类收到了类加载请求,它首先不会尝试自己去加载这个类,而是把这个请求委派交给父类去完成,每一个层次的类加载器都是如此,因此所有加载请求都应该传到启动类加载器中,只有父类加载器反馈自身无法完成这个请求(在它的加载路径下没有找到所需加载的class),子类加载器才会尝试自己去加载。
这样做的好处是Java类随着它的类加载器一起具备了一种带有优先级的层次关系,通过这种层级关可以避免类的重复加载,同时保证了沙箱安全。
简单来说就是怼到顶,没有再往下层找,通俗理解为买东西能花爸爸的钱就不要花自己的零花钱,爸爸也是这么想的,所以一般都花爷爷的钱,但是爷爷都是用现金,没开WeChat,zfb等,有些东西买不了,所以就会让爸爸甚至儿子的钱去买…
沙箱安全
沙箱机制就是将 Java 代码限定在虚拟机(JVM)特定的运行范围中,并且严格限制代码对本地系统资源访问,通过这样的措施来保证对代码的有效隔离,防止对本地系统造成破坏
简单来说就是,防止用户自己写的恶意代码去污染java本身的源代码。