专栏首页余林丰虚拟机类加载机制(3)——线程上下文类加载器

虚拟机类加载机制(3)——线程上下文类加载器

之所以将线程上下文类加载器(Thread Context ClassLoader)单独拿出来写,确实是因为它涉及的东西比较多,既然带有线程两个字,一定也是非常重要的一个东西。

我们首先来回顾一下类加载器的双亲委派模型。

在上一章《虚拟机类加载机制(2)——类加载器》中我们解释了何为类加载器的“双亲委派模型”,知道了双亲委派模型给我们带了一个好处就是Java类随着它的类一起具备了一种带有优先级的层次关系。简单的例子就是Object类在程序的各种类加载环境中都会由启动类加载器来加载,换言之,它无论在什么环境中都是同一个Object类。但是有时候我们可能需要“打破”双亲委派模型。双亲委派模型让我们加载基础类的时候都是同一个基础类,但我们有时候可能需要在基础类中回调用户代码怎么办呢?“基础类中回调用户代码”可能不大好理解,我们列举一个例子来说明:Java提供了很多服务提供者接口(SPI,Service Provider Interface),允许独立厂商(第三方)为此提供实现。常见的SPI有:JNDI、JDBC、JAXP等。这些接口由Java的核心库来提供,所以问题就在于,SPI的接口是Java核心库的一部分,它们是由启动类加载器来加载的。SPI实现的Java类一般是由应用程序类加载器(Application ClassLoader)来加载的。启动类无法找到SPI的实现类,因为它只加载核心库(SPI的实现类由第三方提供)。它也不能代理给应用程序类加载器,因为它又是应用程序类加载器的父类,双亲委派模型又会将它交给启动类来加载。所以在这个时候我们就要“打破”这个“双亲委派模型”。

这个时候,线程上下文类加载器(Thread Context ClassLoader)很好地解决了这个问题。Thread类中有getContextClassLoader()和setContextClassLoader(ClassLoader cl)方法用来获取和设置上下文类加载器,如果没有setContextClassLoader(ClassLoader cl)方法通过设置类加载器,那么线程将继承父线程的上下文类加载器,如果在应用程序的全局范围内都没有设置的话,那么这个上下文类加载器默认就是应用程序类加载器(Application ClassLoader),换句话说Java默认的线程上下文类加载器就是应用程序类加载器(AppClassLoader)。通过线程上下文来加载第三方库jndi实现,而不依赖于双亲委派。大部分Java Application服务器(jboss, tomcat..)也是采用contextClassLoader来处理web服务(所以理解线程上下文类加载器,更能让我们理解Tomcat等服务器的实现原理、工作方式)。

虚拟机的这几个部分确实有难度,本人经验知识有限也在努力学习中,尚不能给出专业且详尽的分析,这里有一篇介绍上下文类加载的文章可以研读此文。http://blog.csdn.net/zhoudaxia/article/details/35897057

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

我来说两句

0 条评论
登录 后参与评论

相关文章

  • 虚拟机类加载机制(2)——类加载器

    《深入理解Java虚拟机》一书中将类的加载过程放到了类加载器前面一节,但在这里我想先讲“类加载器”。在上一篇类加载时机中我们用大量篇幅来讲解了类加载过程中的5个...

    用户1148394
  • MyBatis之级联小结

    在这之前我们知道了MyBatis为我们提供了三种级联:一对一关系(assocation)、一对多关系(collection)、鉴别器(discriminator...

    用户1148394
  • JVM面试十问

    (1)标记-清除算法:首先标记出需要回收的对象,标记完成后统一清除。此算法缺点是标记-清楚效率不高,且容易出现大量不连续的碎片空间。

    用户1148394
  • 图解Tomcat类加载机制

      说到本篇的tomcat类加载机制,不得不说翻译学习tomcat的初衷。   之前实习的时候学习javaMelody的源码,但是它是一个Maven的项目,...

    用户1154259
  • 类加载过程,双亲委派模型?

    java通过字节码和JVM机制,提供了强大的跨平台能力,理解Java的类加载机制能让我们更加了解java的运行过程

    居士
  • 类加载子系统

    类加载器子系统负责从文件系统或者网络中加载Class文件,class文件在文件开头有特定的文件标识。

    麋鹿大哥
  • JVM笔记二双亲委派机制

    JVM类加载器是什么机制?为什么使用这种机制(这种机制的好处是什么)?说下类加载流程?用代码验证类加载机制。为什么要破坏类的这种加载机制?

    凯哥Java
  • ​2.1.2 类加载器的工作原理与自定义加载器 -《SSM深入解析与项目实战》

    由前面,我们应该都可以知道,Java中的类加载器大致可以分为两类,一类是系统提供的,另一类是由开发者编写的自定义类加载器。系统提供的三个类加载器在前面已经介绍了...

    谙忆
  • JVM真香系列:轻松理解class文件到虚拟机(下)

    上面我们自定义一个String出了问题,问题在于JVM不知道我们想用哪个类,于是JVM就定义了个规范。

    田维常
  • 【JVM系统学习之路】一篇看懂类加载

    嗨喽,小伙伴大家好,我是小春哥,今天是打卡 【JVM系统学习之路】 的第二篇文章 类加载子系统 ,在学习本章节首先回顾 上一章节【JVM系统学习之路】JVM与J...

    山间木匠

扫码关注云+社区

领取腾讯云代金券