JVM类加载机制

一些很基础的东西

  1. Java程序在JVM中运行的
  2. JVM运行的是*.class而非*.java
  3. *.class是由*.java经过编译器(jdk中的javac.exe)编译后得到的
  4. java程序执行前,*.class需要先被类加载器(ClassLoader)加载到JVM中
  5. 类加载器不止一种,它们本身的生成也有一个过程

类加载器生成

windows下java类加载过程
  上图中:

  1. 第一个类加载器是由c++创建的引导类加载器(BootStrapClassLoader)。引导类加载器会加载sun.misc.Launcher类
  2. sun.misc.Launcher是sun.misc.Launcher是类加载器的启动类,它的初始化使用了单例模式,保证一个jvm虚拟机中只有一个sum.misc.launcher实例。
  3. 在sun.misc.Launcher构造方法内部,创建了扩展类加载器(ExtClassLoader)和应用类加载器(AppClassLoader)。我们自己写的java类就是由应用类加载器加载的。
  4. 关于几个类加载器
      引导类加载器(BootStrapClassLoader)。
    在这里插入图片描述

  扩展类加载器(ExtClassLoader)。
在这里插入图片描述
  应用程序类加载器(AppClassLoader)。
在这里插入图片描述

  自定义加载器。
在这里插入图片描述

双亲委派机制

在这里插入图片描述
  显而易见,扩展类加载器和引导类加载器是应用类加载器的双亲。具体流程图(感谢IT烂笔头):
在这里插入图片描述

为什么要用双亲委派机制

  1. 沙箱安全机制。自己写的类如果和jdk类库的路径和包名都一致时不会被应用类加载器加载,从而防止核心api库被随意篡改
  2. 避免类的重复加载。当父类已经加载了该类时,没必要子类ClassLoader再加载一次,保证被加载类的唯一性。
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值