Java 類在 Tomcat 中是如何加載的(過程分析)
說到本篇的Tomcat類加載機(jī)制,不得不說翻譯學(xué)習(xí)Tomcat的初衷。
之前實(shí)習(xí)的時(shí)候?qū)W習(xí)JavaMelody的源碼,但是它是一個(gè)Maven的項(xiàng)目,與我們自己的Web項(xiàng)目整合后無法直接斷點(diǎn)調(diào)試。
后來同事指導(dǎo),說是直接把Java類復(fù)制到src下就可以了。很納悶....為什么會優(yōu)先加載src下的Java文件(編譯出的class),而不是jar包中的class呢?
現(xiàn)在了解Tomcat的類加載機(jī)制,原來一切是這么的簡單。

一、類加載
在JVM中并不是一次性把所有的文件都加載到,而是一步一步的,按照需要來加載。
比如JVM啟動時(shí),會通過不同的類加載器加載不同的類。當(dāng)用戶在自己的代碼中,需要某些額外的類時(shí),再通過加載機(jī)制加載到JVM中,并且存放一段時(shí)間,便于頻繁使用。
因此使用哪種類加載器、在什么位置加載類都是JVM中重要的知識。
二、JVM類加載
JVM類加載采用:父類委托機(jī)制,如下圖所示:

JVM中包括集中類加載器:
BootStrapClassLoader 引導(dǎo)類加載器
ExtClassLoader 擴(kuò)展類加載器
AppClassLoader 應(yīng)用類加載器
CustomClassLoader 用戶自定義類加載器
他們的區(qū)別上面也都有說明。需要注意的是,不同的類加載器加載的類是不同的,因此如果用戶加載器1加載的某個(gè)類,其他用戶并不能夠使用。
當(dāng)JVM運(yùn)行過程中,用戶需要加載某些類時(shí),會按照下面的步驟(父類委托機(jī)制):
用戶自己的類加載器,把加載請求傳給父加載器,父加載器再傳給其父加載器,一直到加載器樹的頂層。
最頂層的類加載器首先針對其特定的位置加載,如果加載不到就轉(zhuǎn)交給子類。
如果一直到底層的類加載都沒有加載到,那么就會拋出異常ClassNotFoundException。
因此,按照這個(gè)過程可以想到,如果同樣在CLASSPATH指定的目錄中和自己工作目錄中存放相同的class,會優(yōu)先加載CLASSPATH目錄中的文件。
三、Tomcat類加載
在Tomcat中類的加載稍有不同,如下圖:

當(dāng)Tomcat啟動時(shí),會創(chuàng)建幾種類加載器:
1、Bootstrap 引導(dǎo)類加載器
加載JVM啟動所需的類,以及標(biāo)準(zhǔn)擴(kuò)展類(位于jre/lib/ext下)
2、System 系統(tǒng)類加載器
加載Tomcat啟動的類,比如bootstrap.jar,通常在catalina.bat或者catalina.sh中指定。位于CATALINA_HOME/bin下。

3、Common 通用類加載器
加載Tomcat使用以及應(yīng)用通用的一些類,位于CATALINA_HOME/lib下,比如servlet-api.jar

4、webapp 應(yīng)用類加載器
每個(gè)應(yīng)用在部署后,都會創(chuàng)建一個(gè)唯一的類加載器。該類加載器會加載位于 WEB-INF/lib下的jar文件中的class 和 WEB-INF/classes下的class文件。Tomcat 的 Server 文件配置詳解!這篇推薦大家看下。
當(dāng)應(yīng)用需要到某個(gè)類時(shí),則會按照下面的順序進(jìn)行類加載:
1、使用bootstrap引導(dǎo)類加載器加載
2、使用system系統(tǒng)類加載器加載
3、使用應(yīng)用類加載器在WEB-INF/classes中加載
4、使用應(yīng)用類加載器在WEB-INF/lib中加載
5、使用common類加載器在CATALINA_HOME/lib中加載
四、問題擴(kuò)展
通過對上面Tomcat類加載機(jī)制的理解,就不難明白 為什么Java文件放在Eclipse中的src文件夾下會優(yōu)先jar包中的class?
這是因?yàn)镋clipse中的src文件夾中的文件Java以及webContent中的JSP都會在Tomcat啟動時(shí),被編譯成class文件放在 WEB-INF/class中。
而Eclipse外部引用的jar包,則相當(dāng)于放在 WEB-INF/lib 中。
因此肯定是 Java文件或者JSP文件編譯出的class優(yōu)先加載。
通過這樣,我們就可以簡單的把Java文件放置在src文件夾中,通過對該Java文件的修改以及調(diào)試,便于學(xué)習(xí)擁有源碼Java文件、卻沒有打包成xxx-source的jar包。
另外呢,開發(fā)者也會因?yàn)榇中亩赶旅娴腻e(cuò)誤。
在 CATALINA_HOME/lib 以及 WEB-INF/lib 中放置了 不同版本的jar包,此時(shí)就會導(dǎo)致某些情況下報(bào)加載不到類的錯(cuò)誤。
還有如果多個(gè)應(yīng)用使用同一jar包文件,當(dāng)放置了多份,就可能導(dǎo)致 多個(gè)應(yīng)用間 出現(xiàn)類加載不到的錯(cuò)誤。
推薦去我的博客閱讀更多:
2.Spring MVC、Spring Boot、Spring Cloud 系列教程
3.Maven、Git、Eclipse、Intellij IDEA 系列工具教程
4.Java、后端、架構(gòu)、阿里巴巴等大廠最新面試題
覺得不錯(cuò),別忘了點(diǎn)贊+轉(zhuǎn)發(fā)哦!
到此這篇關(guān)于Java 類在 Tomcat 中是如何加載的過程分析的文章就介紹到這了,更多相關(guān)java 類 tomcat 加載內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
- Java 找不到或無法加載主類的修復(fù)方法
- 源碼解析Java類加載器
- Intellij IDEA命令行執(zhí)行java無法加載主類解決方案
- jvm之java類加載機(jī)制和類加載器(ClassLoader)的用法
- 解決IDEA和CMD中java命令提示錯(cuò)誤: 找不到或無法加載主類的問題
- Java類加載器層次結(jié)構(gòu)原理解析
- Java類加載機(jī)制實(shí)現(xiàn)流程及原理詳解
- Java類加載機(jī)制實(shí)現(xiàn)步驟解析
- Java基于自定義類加載器實(shí)現(xiàn)熱部署過程解析
- 兩種實(shí)現(xiàn)Java類隔離加載的方法
相關(guān)文章
JDK1.7中HashMap的死循環(huán)問題及解決方案
這篇文章主要為大家介紹了JDK1.7中HashMap的死循環(huán)問題及解決方案,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-10-10
Java(Springboot)項(xiàng)目調(diào)用第三方WebService接口實(shí)現(xiàn)代碼
這篇文章主要介紹了如何使用Java調(diào)用WebService接口,傳遞XML參數(shù),獲取XML響應(yīng),并將其解析為JSON格式,文中詳細(xì)描述了WSDL文檔的使用、HttpClientBuilder和Apache?Axis兩種調(diào)用方式的具體實(shí)現(xiàn)步驟,需要的朋友可以參考下2025-02-02
Spring Boot集成tablesaw插件快速入門示例代碼
Tablesaw是一款Java的數(shù)據(jù)可視化庫,數(shù)據(jù)解析庫,主要用于加載數(shù)據(jù),對數(shù)據(jù)進(jìn)行操作(轉(zhuǎn)化,過濾,匯總等),類比Python中的Pandas庫,本文介紹Spring Boot集成tablesaw插件快速入門Demo,感興趣的朋友一起看看吧2024-06-06
Mybatis-Plus雪花id的使用以及解析機(jī)器ID和數(shù)據(jù)標(biāo)識ID實(shí)現(xiàn)
這篇文章主要介紹了Mybatis-Plus雪花id的使用以及解析機(jī)器ID和數(shù)據(jù)標(biāo)識ID實(shí)現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-08-08
Java實(shí)現(xiàn)word/pdf轉(zhuǎn)html并在線預(yù)覽
這篇文章主要為大家詳細(xì)介紹了如何利用Java語言實(shí)現(xiàn)word、pdf文件轉(zhuǎn)html并在線預(yù)覽的功能,文中的示例代碼講解詳細(xì),需要的可以參考一下2023-05-05
詳解mybatis批量插入10萬條數(shù)據(jù)的優(yōu)化過程
這篇文章主要介紹了詳解mybatis批量插入10萬條數(shù)據(jù)的優(yōu)化過程,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2021-04-04
詳解mybatis 批量更新數(shù)據(jù)兩種方法效率對比
這篇文章主要介紹了詳解mybatis 批量更新數(shù)據(jù)兩種方法效率對比,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2019-02-02

