中科永聯(lián)高級(jí)技術(shù)培訓(xùn)中心(www.) JRE(Java Runtime Environment,Java運(yùn)行環(huán)境),運(yùn)行JAVA程序所必須的環(huán)境的集合,包含JVM標(biāo)準(zhǔn)實(shí)現(xiàn)及Java核心類庫(kù)。 jre為JavaRunTimeEnvirment的簡(jiǎn)稱,JavaRuntimeEnvironment(包括JavaPlug-in)是Sun的產(chǎn) 品,包括兩部分:JavaRuntimeEnvironment和JavaPlug-inJavaRuntimeEnvironment(JRE)是可以 在其上運(yùn)行、測(cè)試和傳輸應(yīng)用程序的Java平臺(tái)。它包括Java虛擬機(jī)、Java平臺(tái)核心類和支持文件。它不包含開發(fā)工具--編譯器、調(diào)試器和其它工具。JRE需要輔助軟件--JavaPlug-in--以便在瀏覽器中運(yùn)行applet。 JavaPlug-in軟件允許Javaapplet和JavaBeans組件在使用Sun的JavaRuntimeEnvironment(JRE)的瀏覽器中運(yùn)行,而不是在使用缺省的Java運(yùn)行環(huán)境的瀏覽器中運(yùn)行。JavaPlug-in可用于NetscapeNavigator和MicrosoftInternetExplorer。 J2RE是Java2 Runtime Environment,即Java運(yùn)行環(huán)境,有時(shí)簡(jiǎn)稱JRE。如果你只需要運(yùn)行Java程序或Applet,下載并安裝它即可。如果你要自行開發(fā) Java軟件,請(qǐng)下載JDK。在JDK中附帶有JRE。注意由于Microsoft對(duì)Java的支持不完全,請(qǐng)不要使用IE自帶的虛擬機(jī)來運(yùn)行 Applet,務(wù)必安裝一個(gè)JRE或JDK。 一、JRE的版本管理 Java的解決辦法是每個(gè)程序自己攜帶一套JRE。 我的機(jī)器上已經(jīng)被安裝了好多套JRE和JDK了(JDK包括了同版本的JRE,此外還包括有編譯器和其它工具),它們分別是: 6套JRE,每套JRE都被各自安裝到不同的目錄,不會(huì)互相影響。當(dāng)在控制臺(tái)執(zhí)行java.exe,操作系統(tǒng)尋找JRE的方式如下: 先找當(dāng)前目錄下有沒有JRE 最常用的是在PATH路徑中找JRE,一般情況下,自己的程序運(yùn)行之前都會(huì)先在批處理文件里面臨時(shí)設(shè)置PATH,把自己用的JRE放到PATH路徑最前面,所以肯定會(huì)運(yùn)行自己帶的JRE,不會(huì)造成版本混亂。 .Net Framework的版本管理 .Net Framework被固定安裝在C:\Winnt\Microsoft.NET\Framework\v版本號(hào)\目錄下,并且在同一臺(tái)機(jī)器只能安裝一套, 要安裝1.1版本的.Net Framework,就必須先刪除1.0的。聽說剛發(fā)行的.Net Framework1.1已經(jīng)對(duì)1.0做了很多改進(jìn),甚至基礎(chǔ)類庫(kù)的層次也有所變動(dòng)??磥碓谂f版本的.Net Framework開發(fā)的程序?qū)硗掳姹旧厦孢w移的時(shí)候少不了修改程序代碼。 二、JRE的基礎(chǔ)類庫(kù) JRE自帶的基礎(chǔ)類庫(kù)主要是JRE\lib\rt.jar這個(gè)文件,包括了Java2平臺(tái)標(biāo)準(zhǔn)版的所有類庫(kù)。和JRE的版本一致。 .Net Framekwork的核心類庫(kù) .Net Framekwork的核心類庫(kù)被放置在C:\Winnt\assembly\gac\目錄下,按照不同的名稱空間放在不同目錄中,不像JRE打成了一個(gè)包。并且可以同時(shí)存在不同的版本,例如: 這樣做,雖然很靈活,可以隨時(shí)把類庫(kù)更新到最新的狀態(tài),但是很容易帶來版本管理的復(fù)雜度,造成版本不一致。 三、JRE類庫(kù)的查找方法和版本管理 JRE中由ClassLoader負(fù)責(zé)查找和加載程序引用到的類庫(kù),基礎(chǔ)類庫(kù)ClassLoader會(huì)到rt.jar中自動(dòng)加載,其它的類庫(kù), ClassLoader在環(huán)境變量CLASSPATH指定的路徑中搜索,按照先來先到的原則,放在CLASSPATH前面的類庫(kù)先被搜到,Java程序啟 動(dòng)之前建議先把PATH和CLASSPATH環(huán)境變量設(shè)好,OS通 過PATH來找JRE,確定基礎(chǔ)類庫(kù)rt.jar的位置,JRE的ClassLoader通過CLASSPATH找其它類庫(kù)。但有時(shí)候會(huì)出現(xiàn)這樣的情況, 希望替換基礎(chǔ)類庫(kù)中的類庫(kù),那么也可以簡(jiǎn)單的通過-Djava.endrosed.path=...參數(shù)傳遞給java.exe,于是 ClassLoader會(huì)先于基礎(chǔ)類庫(kù)使用java.endrosed.path參數(shù)指定路徑的類庫(kù)。因此Java的版本管理是非常簡(jiǎn)單有效的,也許很原 始,不過很好用,簡(jiǎn)單就不容易出錯(cuò)。(所以我很奇怪Eric Ramond為什么批評(píng)Java的類庫(kù)管理機(jī)制,他還居然批評(píng)Java的接口,令人懷疑他對(duì)Java的了解程度) .Net Framework的類庫(kù)管理機(jī)制 .Net Framework的類庫(kù)管理機(jī)制相當(dāng)強(qiáng)大和復(fù)雜,分為私有類庫(kù)和共享類庫(kù)。 也就是可以同時(shí)存在一個(gè)類庫(kù)的n個(gè)版本,至于在程序中用哪個(gè)版本,在程序的配置文件中聲明,CLR會(huì)根據(jù)聲明來調(diào)用相應(yīng)的版本的類庫(kù)。我覺得.Net實(shí)現(xiàn) 方法未免太復(fù)雜了一些,將所有共享類庫(kù)都塞到一個(gè)系統(tǒng)目錄下,并且同一個(gè)類庫(kù)還有n個(gè)版本,將來.Net第三方開發(fā)的類庫(kù)逐漸豐富起來以后,.Net類庫(kù) 的GAC也會(huì)越來越龐大,會(huì)不會(huì)也搞得和Windows注冊(cè)表一樣難以維護(hù)?軟件發(fā)布到服務(wù)器上的時(shí)候,類庫(kù)要再注冊(cè)一次,服務(wù)器會(huì)逐漸形成一個(gè)龐大的樹 狀的GAC,GAC里面存放著組件的n個(gè)版本。試想經(jīng)過一段時(shí)間之后,C:\Winnt\assembly\gac\目錄會(huì)越來越龐大,有的組件甚至有n 個(gè)版本都放在那里,你又不敢隨便刪除,不知道是不是有程序需要使用,我不明白MS為什么要把這么簡(jiǎn)單的事情搞到這么復(fù)雜?
|
|