色综合图-色综合图片-色综合图片二区150p-色综合图区-玖玖国产精品视频-玖玖香蕉视频

您的位置:首頁(yè)技術(shù)文章
文章詳情頁(yè)

Java 類在 Tomcat 中是如何加載的(過(guò)程分析)

瀏覽:2日期:2022-08-28 16:03:13

說(shuō)到本篇的Tomcat類加載機(jī)制,不得不說(shuō)翻譯學(xué)習(xí)Tomcat的初衷。

之前實(shí)習(xí)的時(shí)候?qū)W習(xí)JavaMelody的源碼,但是它是一個(gè)Maven的項(xiàng)目,與我們自己的Web項(xiàng)目整合后無(wú)法直接斷點(diǎn)調(diào)試。

后來(lái)同事指導(dǎo),說(shuō)是直接把Java類復(fù)制到src下就可以了。很納悶....為什么會(huì)優(yōu)先加載src下的Java文件(編譯出的class),而不是jar包中的class呢?

現(xiàn)在了解Tomcat的類加載機(jī)制,原來(lái)一切是這么的簡(jiǎn)單。

Java 類在 Tomcat 中是如何加載的(過(guò)程分析)

一、類加載

在JVM中并不是一次性把所有的文件都加載到,而是一步一步的,按照需要來(lái)加載。

比如JVM啟動(dòng)時(shí),會(huì)通過(guò)不同的類加載器加載不同的類。當(dāng)用戶在自己的代碼中,需要某些額外的類時(shí),再通過(guò)加載機(jī)制加載到JVM中,并且存放一段時(shí)間,便于頻繁使用。

因此使用哪種類加載器、在什么位置加載類都是JVM中重要的知識(shí)。

二、JVM類加載

JVM類加載采用:父類委托機(jī)制,如下圖所示:

Java 類在 Tomcat 中是如何加載的(過(guò)程分析)

JVM中包括集中類加載器:

BootStrapClassLoader 引導(dǎo)類加載器

ExtClassLoader 擴(kuò)展類加載器

AppClassLoader 應(yīng)用類加載器

CustomClassLoader 用戶自定義類加載器

他們的區(qū)別上面也都有說(shuō)明。需要注意的是,不同的類加載器加載的類是不同的,因此如果用戶加載器1加載的某個(gè)類,其他用戶并不能夠使用。

當(dāng)JVM運(yùn)行過(guò)程中,用戶需要加載某些類時(shí),會(huì)按照下面的步驟(父類委托機(jī)制):

用戶自己的類加載器,把加載請(qǐng)求傳給父加載器,父加載器再傳給其父加載器,一直到加載器樹(shù)的頂層。

最頂層的類加載器首先針對(duì)其特定的位置加載,如果加載不到就轉(zhuǎn)交給子類。

如果一直到底層的類加載都沒(méi)有加載到,那么就會(huì)拋出異常ClassNotFoundException。

因此,按照這個(gè)過(guò)程可以想到,如果同樣在CLASSPATH指定的目錄中和自己工作目錄中存放相同的class,會(huì)優(yōu)先加載CLASSPATH目錄中的文件。

三、Tomcat類加載

在Tomcat中類的加載稍有不同,如下圖:

Java 類在 Tomcat 中是如何加載的(過(guò)程分析)

當(dāng)Tomcat啟動(dòng)時(shí),會(huì)創(chuàng)建幾種類加載器:

1、Bootstrap 引導(dǎo)類加載器

加載JVM啟動(dòng)所需的類,以及標(biāo)準(zhǔn)擴(kuò)展類(位于jre/lib/ext下)

2、System 系統(tǒng)類加載器

加載Tomcat啟動(dòng)的類,比如bootstrap.jar,通常在catalina.bat或者catalina.sh中指定。位于CATALINA_HOME/bin下。

Java 類在 Tomcat 中是如何加載的(過(guò)程分析)

3、Common 通用類加載器

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

Java 類在 Tomcat 中是如何加載的(過(guò)程分析)

4、webapp 應(yīng)用類加載器

每個(gè)應(yīng)用在部署后,都會(huì)創(chuàng)建一個(gè)唯一的類加載器。該類加載器會(huì)加載位于 WEB-INF/lib下的jar文件中的class 和 WEB-INF/classes下的class文件。Tomcat 的 Server 文件配置詳解!這篇推薦大家看下。

當(dāng)應(yīng)用需要到某個(gè)類時(shí),則會(huì)按照下面的順序進(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中加載

四、問(wèn)題擴(kuò)展

通過(guò)對(duì)上面Tomcat類加載機(jī)制的理解,就不難明白 為什么Java文件放在Eclipse中的src文件夾下會(huì)優(yōu)先jar包中的class?

這是因?yàn)镋clipse中的src文件夾中的文件Java以及webContent中的JSP都會(huì)在Tomcat啟動(dòng)時(shí),被編譯成class文件放在 WEB-INF/class中。

而Eclipse外部引用的jar包,則相當(dāng)于放在 WEB-INF/lib 中。

因此肯定是 Java文件或者JSP文件編譯出的class優(yōu)先加載。

通過(guò)這樣,我們就可以簡(jiǎn)單的把Java文件放置在src文件夾中,通過(guò)對(duì)該Java文件的修改以及調(diào)試,便于學(xué)習(xí)擁有源碼Java文件、卻沒(méi)有打包成xxx-source的jar包。

另外呢,開(kāi)發(fā)者也會(huì)因?yàn)榇中亩赶旅娴腻e(cuò)誤。

在 CATALINA_HOME/lib 以及 WEB-INF/lib 中放置了 不同版本的jar包,此時(shí)就會(huì)導(dǎo)致某些情況下報(bào)加載不到類的錯(cuò)誤。

還有如果多個(gè)應(yīng)用使用同一jar包文件,當(dāng)放置了多份,就可能導(dǎo)致 多個(gè)應(yīng)用間 出現(xiàn)類加載不到的錯(cuò)誤。

推薦去我的博客閱讀更多:

1.Java JVM、集合、多線程、新特性系列教程

2.Spring MVC、Spring Boot、Spring Cloud 系列教程

3.Maven、Git、Eclipse、Intellij IDEA 系列工具教程

4.Java、后端、架構(gòu)、阿里巴巴等大廠最新面試題

覺(jué)得不錯(cuò),別忘了點(diǎn)贊+轉(zhuǎn)發(fā)哦!

到此這篇關(guān)于Java 類在 Tomcat 中是如何加載的過(guò)程分析的文章就介紹到這了,更多相關(guān)java 類 tomcat 加載內(nèi)容請(qǐng)搜索好吧啦網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持好吧啦網(wǎng)!

標(biāo)簽: Java
相關(guān)文章:
主站蜘蛛池模板: 午夜在线播放免费人成无 | 亚洲天堂日韩在线 | cao美女 | 日本韩国三级在线观看 | 成人午夜做爰视频免费看 | 免费成人| 国产精品嘿咻嘿咻在线播放 | 欧美一级专区免费大片野外交 | 亚洲一区二区三区欧美 | 久久精品免费视频观看 | 国产高清国产专区国产精品 | 不卡一区在线观看 | 另类视频综合 | 亚洲第一视频在线播放 | 日韩中文字幕在线免费观看 | 大伊香蕉精品视频在线观看 | 青青影院一区二区免费视频 | 91精品在线国产 | 欧美zoofilia杂交videos | 能看毛片的网址 | 性一级片 | 久久全国免费久久青青小草 | 日韩高清一级 | 性感美女视频免费网站午夜 | 高h原耽肉汁动漫视频 | 亚洲第一se情网站 | 在线观看免费黄视频 | 特级欧美午夜aa毛片 | 亚洲日本中文字幕在线 | 久久精品午夜 | 国产一级网站 | 欧美人在线一区二区三区 | 色综合久久88中文字幕 | 成人欧美一区二区三区视频xxx | 精品日本一区二区三区在线观看 | 精品一区二区三区五区六区 | 欧美成人eee在线 | 成年人免费观看网站 | 亚洲精品视频在线 | 亚洲性生活视频 | 欧美成人免费午夜影视 |