NoClassDefDoundErr與ClassNotFoundException區(qū)別
作者:langm
版權(quán)聲明:本文可以自由轉(zhuǎn)載,轉(zhuǎn)載時(shí)請(qǐng)務(wù)必以超鏈接形式標(biāo)明文章原始出處和作者信息及本聲明
作者:langm
原文:http://www.matrix.org.cn/resource/article/44/44056_NoClassDefDoundErr.html
關(guān)鍵字:NoClassDefDoundErr ClassNotFoundException
在讀這篇文章之前,你最好了解一下Java的Exception機(jī)制。
也許你在開發(fā)的過程中經(jīng)常地見到ClassNotFoundException和NoClassDefFoundErr這兩個(gè)異常,每每看到之后,都會(huì)一概而論的是類沒有找到,但有些時(shí)候見到他們的時(shí)候又有些疑惑(至少我是這樣),為什么Java要用兩個(gè)異常來表示類定義沒有找到那?他們之間有什么區(qū)別那?
正巧今天我又碰到了這個(gè)問題,順便的仔細(xì)研究了一下這兩個(gè)異常的區(qū)別。
首先:
ClassNotFoundException直接繼承與Exception,它是一個(gè)checked的異常。
NoClassDefFoundErr 繼承自Error->LinkageError ,它是一個(gè)unchecked的異常。
下面讓我們看一下兩個(gè)異常在API文檔中的說明
ClassNotFoundException:
當(dāng)應(yīng)用嘗試用字符串名稱通過下面的方法裝載一個(gè)類時(shí)這個(gè)類的定義卻沒有找到時(shí)會(huì)拋出的異常。
Class.forName
ClassLoader.findSystemClass
ClassLoader.loadClass
NoClassDefFoundErr:
當(dāng)JVM或者ClassLoader實(shí)例嘗試裝載一個(gè)類的定義(這通常是一個(gè)方法調(diào)用或者new表達(dá)式創(chuàng)建一個(gè)實(shí)例過程的一部分)而這個(gè)類定義并沒有找時(shí)所拋出的錯(cuò)誤。
當(dāng)編譯的時(shí)候可以找到這個(gè)類的定義,但是以后這個(gè)類不再存在。
這比較顯而易見了吧,讀好文檔是很重要的事情。這里我就說一下我對(duì)這兩個(gè)類的區(qū)別的理解。
ClassNotFoundException異常只出現(xiàn)在你的應(yīng)用程序主動(dòng)的裝載類的過程中,這個(gè)異常很多時(shí)候出現(xiàn)在我們的應(yīng)用框架在初始化或者運(yùn)行中動(dòng)態(tài)裝載已配置的類的過程中。這種情況下我們應(yīng)該首先檢查我們的配置或者參數(shù)是否錯(cuò)誤,是否企圖裝載一個(gè)并不存在的類,如果配置沒有錯(cuò)誤,我們就應(yīng)該查看Classpath是否配置錯(cuò)誤而導(dǎo)致ClassLoader無法找到這個(gè)類,也應(yīng)該檢查要裝載的類是否在一個(gè)jar包中而我們?cè)谝脒@個(gè)jar包的過程中是否有遺漏或錯(cuò)誤(這里jar包的版本也是一個(gè)需要格外注意的問題,很多時(shí)候混亂的jar包版本會(huì)造成太多的麻煩)。
NoClassDefFoundErr異常一般出現(xiàn)在我們編譯環(huán)境和運(yùn)行環(huán)境不一致的情況下,就是說我們有可能在編譯過后更改了Classpath或者jar包所以導(dǎo)致在運(yùn)行的過程中JVM或者ClassLoader無法找到這個(gè)類的定義(我曾經(jīng)在編譯后作了一次jar包的清理,然后應(yīng)用就送給了我一個(gè)這樣的禮物)。
我們經(jīng)常用SDK開發(fā)應(yīng)用,開發(fā)的過程中要引入很多jar包,有些SDK也會(huì)設(shè)定自己的Classpath。編譯過程結(jié)束后在運(yùn)行的過程中就要將已開發(fā)的應(yīng)用和所有引入的jar包拷貝到應(yīng)用服務(wù)器的相應(yīng)目錄下才可以運(yùn)行,而應(yīng)用服務(wù)器使用的Classpath也很有可能與SDK的不同,在這個(gè)過程中就有很大的幾率造成雙方環(huán)境不一致。所以很多開發(fā)者就會(huì)遇到在SDK中可以編譯,運(yùn)行也沒有問題,但是同樣的程序放到應(yīng)用服務(wù)器上就出現(xiàn)NoClassDefFoundErr這個(gè)異常這種情況,這是讓初學(xué)者很撓頭的一個(gè)問題。
以上就是我對(duì)這兩個(gè)異常的一點(diǎn)個(gè)人理解,希望對(duì)各位開發(fā)者有所幫助,可以讓各位開發(fā)者在以后的開發(fā)過程中能夠更快的找到問題所在。祝開發(fā)順利