java优化系列二 jvm架构

JVM 体系结构概览

java优化系列二 jvm架构_第1张图片

java优化系列二 jvm架构_第2张图片

类装载器 ClassLoader

父对象是Object,负责加载class文件,class文件在文件开头有特定的文件标示,
并且ClassLoader只负责class文件的加载,至于是否可以运行,则由Execution Engine 决定

java优化系列二 jvm架构_第3张图片

ClassLoader2

java优化系列二 jvm架构_第4张图片

    public void testClassLoader01(){
        /**
         * null  找不到  根ClassLoader 是C++写的  JAVA拿不到
         * jdk.internal.loader.ClassLoaders$PlatformClassLoader@41a23470
         * jdk.internal.loader.ClassLoaders$AppClassLoader@3d4eac69  系统ClassLoader
         * null  空说明是bootstrap
         */
        System.out.println(new DemoApplicationTests().getClass().getClassLoader().getParent().getParent());
        System.out.println(new DemoApplicationTests().getClass().getClassLoader().getParent() );
        System.out.println(new DemoApplicationTests().getClass().getClassLoader());
        System.out.println(new String().getClass().getClassLoader());
    }

双亲委派模式简介

	双亲委派模式的工作原理的是;如果一个类加载器收到了类加载请求,它并不会自己先去加载,而是把这个请求委托
	给父类的加载器去执行,如果父类加载器还存在其父类加载器,则进一步向上委托,依次递归,请求最终将到达顶层
	的启动类加载器,如果父类加载器可以完成类加载任务,就成功返回,倘若父类加载器无法完成此加载任务,子加载
	器才会尝试自己去加载,这就是双亲委派模式,即每个儿子都不愿意干活,每次有活就丢给父亲去干,直到父亲说这
	件事我也干不了时,儿子自己想办法去完成,这不就是传说中的双亲委派模式.那么这种模式有什么作用呢?

在此首先要介绍下ClassLoader。说ClassLoader之前,我们得先了解下Java的基本知识。 Java是运行在Java的虚拟机(JVM)中的,但是它是怎么就运行在JVM中了呢?我们在IDE中编写的Java源代码被编译器编译成.class的字节码文件。然后由我们得ClassLoader负责将这些class问价加载到JVM中去执行。
JVM中提供了三层的ClassLoader:

	Bootstrap classLoader:主要负责加载核心的类库(java.lang.*等),构造ExtClassLoader和APPClassLoader。
	ExtClassLoader:主要负责加载jre/lib/ext目录下的一些扩展的jar。
	AppClassLoader:主要负责加载应用程序的主函数类

双亲委派的好处

采用双亲委派模式的是好处是Java类随着它的类加载器一起具备了一种带有优先级的层次关系,通过这种层级关可以避
免类的重复加载,当父亲已经加载了该类时,就没有必要子ClassLoader再加载一次。
其次是考虑到安全因素,java核心api中定义类型不会被随意替换,假设通过网络传递一个名为java.lang.Integer的类,
通过双亲委托模式传递到启动类加载器,而启动类加载器在核心Java API发现这个名字的类,发现该类已被加载,并不
会重新加载网络传递的过来的java.lang.Integer,而直接返回已加载过的Integer.class,
这样便可以防止核心API库被随意篡改。

https://blog.csdn.net/u013668852/article/details/88621162

你可能感兴趣的:(JVM调优)