亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 學院 > 開發設計 > 正文

關于java.exe是如何載入JVM

2019-11-18 14:30:40
字體:
來源:轉載
供稿:網友

  將會生成如下3個項目:
  HKEY_LOCAL_MACHINE/SOFTWARE/javaSoft/Java Development Kit
  HKEY_LOCAL_MACHINE/SOFTWARE/JavaSoft/Java Plug-in
  HKEY_LOCAL_MACHINE/SOFTWARE/JavaSoft/Java Runtime Environment
  
  同時,Java2 SDK安裝程序將會把java.exe,javaw.exe,javareg.exe這3個可執行文件拷貝到winnt/system32目錄下,由于winnt/system32被操作系統缺省的設置為最高優先權的PATH搜索路徑,因此可保證用戶在命令行任何目錄下可運行java.exe來啟動JVM。
  
  那么java.exe在啟動時如何確定其JRE所在的目錄以及需要動態加載的鏈接庫呢?java.exe是通過下面方式來確定的:
  
  假如存在../jre/bin/java.dll文件,則查找../jre/lib/ jvm.cfg文件,在該文件中,第1個被列出的jvm.dll類型作為缺省值(假如在java.exe命令行指定了jvm.dll的類型,則使用指定類型)。jvm.dll類型分為hotspot,classic,server三種。假如不存在../jre/lib/jvm.cfg文件,則打印下面的錯誤信息:
  
  Error: could not open 'c:/jdk1.3/jre/lib/jvm.cfg'
  
  如不存在../jre/bin/java.dll(當運行的是winnt/system32/java.exe),則注冊表將在此時發揮作用,HKEY_LOCAL_MACHINE/SOFTWARE/JavaSoft/Java Runtime Environment/ CurrentVersion鍵值所記錄的實際上是winnt/system32/java.exe的版本值,該版本值只保存主、次兩個版本號,如1.2,1.3等。
  
  同時java.exe程序內部本身也有一個標識自身的版本值,如1.2、1.3等。java.exe根據自己內部的版本值和CurrentVersion值相比較,假如發現兩個值相等,則將在HKEY_LOCAL_MACHINE/SOFTWARE/JavaSoft/Java Runtime Environment/MainVersion.MicroVersion項下獲取JRE所在目錄及動態鏈接庫,這兩個鍵的名稱分別是JavaHome和RuntimeLib,MainVersion表示主版本號,MicroVersion表示次版本號。
  
  假如java.exe內部版本值和CurrentVersion不一致,則報類似以下的錯誤:
  
  Registry key 'Software/JavaSoft/Java Runtime Environment/CurrentVersion'
  has value '1.2', but '1.3' is required.
  
  意思是說,注冊表當前所記載的winnt/system32/java.exe版本為1.2,但是此時運行的java.exe版本為1.3。java.exe抱怨除非注冊表有1.3版的記載,否則自己無法正確定位JRE目錄和jvm.dll,因此提示1.3是需要的。
  
  這里,我們不能簡單的修改注冊表的CurrentVersion值來達到這個目的。一般地,當在系統中裝了兩套版本的Java2 SDK(如先裝1.2而后又裝了1.3),后面安裝的Java2 SDK會將自己帶的java.exe和javaw.exe拷貝到winnt/system32目錄下,從而覆蓋先前版本的java.exe和javaw.exe,并且在注冊表中改寫CurrentVersion為1.3。所以建議在安裝Java2 SDK前,先卸載以前安裝的版本。假如人為的修改CurrentVersion,會使得不同版本的java.exe加載與己版本不符的java.dll及jvm.dll,將引起難以預料的后果!
  
  非凡情況:
  JBuilder自己帶一套JDK,在JBuilder安裝完成后,JBuilder安裝程序會修改CurrentVersion為自己所帶JDK的版本,但不會覆蓋winnt/system32下的java.exe和javaw.exe。
  
  WebLogic自己帶一套JDK,在WebLogic安裝完成后,WebLogic安裝程序不會修改注冊表,也不會覆蓋winnt/system32下的java.exe和javaw.exe。
  
  Oracle自己帶一套JDK(一般是比較低版本的,例如8.1.7僅僅帶JDK 1.1.7),在Oracle安裝完成后,Oracle安裝程序不會修改注冊表,也不會覆蓋winnt/system32下的java.exe和javaw.exe。但是,Oralce安裝程序會修改系統PATH變量,將自帶的JRE的bin路徑加入其中,且置于最前面。隨著Oracle安裝版本的不同,其自帶JRE的JVM啟動程序也不同。在筆者機器上安裝的Oracle 8.1.7,其JRE就裝在C:/PRogram Files/Oracle下,并將C:/Program Files/Oracle/jre/1.1.7/bin放在PATH變量最前,其JVM啟動程序是jre.exe而非java.exe。
  
  以上就是Java2 SDK在Windows下安裝時所做的動作,這樣會帶來兼容性問題:
  
  問題背景:安裝Java2 SDK后,安裝了JBuilder6,未修改任何PATH變量
  
  問題1
  當在操作系統中安裝了JDK 1.2,其后安裝了JBuilder6(自帶JDK 1.3.1),這時CurrentVersion為1.3,在命令行執行java -version時,提示:
  
  Registry key 'Software/JavaSoft/Java Runtime Environment/CurrentVersion'
  has value '1.3', but '1.2' is required.
  
  解決方法:將JDK 1.2中java.exe所在路徑加入到操作系統PATH的首位,從而保證在命令行調用java時總是執行JDK 1.2中的java.exe,以使得java.exe可正確定位JRE和jvm.dll。
  
  問題2
  當在操作系統中安裝了JDK 1.3.0,而后安裝了JBuilder6(自帶JDK 1.3.1),這時CurrentVersion為1.3,但是此1.3是指向的是JBuilder6自帶的JDK 1.3.1的JRE,而非指向先前JDK 1.3.0的JRE,當在命令行執行java -version時,此時執行的是JDK 1.3.0拷貝到winnt/system32的一個java.exe副本,但打印的版本信息卻是:
  
  java version "1.3.1"
  Java(TM) 2 Runtime Environment, Standard Edition (build 1.3.1-b24)
  Java HotSpot(TM) Client VM (build 1.3.1-b24, mixed mode)
  
  導致該問題的原因是java.exe只維護小數點后1位的版本號,而非2位。
  
  解決方法:同問題1
  問題3:
  假如在操作系統中先安裝了JDK 1.3.0,而后安裝了帶有與安裝JDK主次版本相同的JBuilder6(帶JDK 1.3.1,前兩位相同),則問題1實際上被隱蔽了,沒有發生的機會;而問題2的隱蔽性也很強,不輕易發覺,因為人們往往會忽略JDK的第3個版本號。
  
  如問題2所敘,在命令行執行java,雖然是使用JDK 1.3.0的一個java.exe副本(winnt/system32目錄下),而實際上卻是使用JBuilder6下JDK 1.3.1的JRE及其目錄結構,其結果是當我們使用Java2的extension mechanism將jar文件放到JDK 1.3.0的jre/lib/ext目錄下時,發現達不到希望的效果 ? 在命令行用java啟動程序時,不會自動去JDK 1.3.0的jre/lib/ext目錄下去搜索jar文件,它只會去JBuilder6下JDK 1.3.1的jre/lib/ext去搜索jar文件,而JBuilder6下的JDK 1.3.1并不存在jre/lib/ext這么一個目錄!
  
  問題3極為隱蔽,除非完全對Java2 SDK的安裝及class定位機制了解,一般的開發者是難以發現問題所在的。有關Java2中class定位機制,見《Java2中的class定位機制》一文。
  
  事實上,即使僅僅在系統中存在一份JDK 1.3.0,假如在命令行運行java的話,使用的JRE目錄是C:/Program Files/JavaSoft/JRE/1.3,也就是說,即使我們在c:/jdk1.3/jre/lib/ext下放置我們的extension jar,也得不到預期的結果。正確的做法是放在C:/Program Files/JavaSoft/JRE/1.3/lib/ext目錄下。
  
  解決方法:同問題1
  綜上所敘,強烈建議將%JDK_HOME%/bin目錄放在Windows操作系統的PATH變量的首位,以避免潛在的問題。
  
  而在UNIX下,則完全不存在類似Windows操作系統上的問題。
  
  我們在命令下執行的java是/bin/java
  
  $which java
  $/bin/java
  
  而/bin是到/usr/bin的鏈接,也就是說/bin/java實際上是/usr/bin/java
  
  而/usr/bin/java實際上鏈接到/usr/java/bin/java,/usr/java是到/usr/java1.2的鏈接(Solaris 7或更高系統內置JDK 1.2),所以我們實際上執行的java是
  
  /usr/java1.2/bin/java
  
  根據UNIX上的情況,java在運行時實際上總是可以用../jre/lib/sparc/libjava.so和../jre/lib/sparc/libjvm.so來找到這2個文件,前者類似于Windows下的java.dll,而后者類似于Windows下的jvm.dll。所以java也總是可以確定自己JRE的目錄。
  
  Windows和UNIX上用到的動態鏈接庫,實際上在Sun的文檔中稱為optional package's native code binaries,optional pakage實際上即為extension mechanism classes,詳見《Java2中的class定位機制》。
  
  要更改UNIX上java的版本,更改/usr/java的鏈接是其中一個方法,具體可參見JDK在UNIX上的安裝介紹。
  
  補充:(2002-12-23)
  
  Windows如何定位Plug-in
  
  根據在PATH環境變量中找到的java.exe的版本號,到HKEY_LOCAL_MACHINE/SOFTWARE/JavaSoft/Java Plug-in下尋找對應版本的Java Plug-in,在HKEY_LOCAL_MACHINE/SOFTWARE/JavaSoft/Java Plug-in下可以有多個版本的Plug-in存在。
  
  不依靠HKEY_LOCAL_MACHINE/SOFTWARE/JavaSoft/Java Development Kit的CurrentVersion值和HKEY_LOCAL_MACHINE/SOFTWARE/JavaSoft/Java Runtime Environment的CurrentVersion值來定位應該使用哪個版本的Java Plug-in。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
欧美成人精品在线观看| 国产亚洲精品91在线| 国产精品午夜国产小视频| 亚洲精品美女久久| 国产91免费看片| 色伦专区97中文字幕| 日韩国产在线播放| 精品久久国产精品| 国产一区二区三区中文| 亚洲精品xxxx| 亚洲国产欧美一区二区三区同亚洲| 欧美一区二区三区图| 欧美一级电影久久| 国产美女扒开尿口久久久| 欧美一区二区大胆人体摄影专业网站| 亚洲国产精品资源| 久久艳片www.17c.com| 日韩精品在线观看一区| 97香蕉久久夜色精品国产| 77777少妇光屁股久久一区| 欧美性猛交xxxx乱大交| 九九九久久国产免费| 亚洲成年网站在线观看| 久久精品电影网| 欧美一级视频免费在线观看| 亚洲91精品在线| 亚洲一级黄色av| 日韩h在线观看| 在线播放国产一区二区三区| 欧美久久精品午夜青青大伊人| 亚洲久久久久久久久久久| 日韩极品精品视频免费观看| 97精品一区二区视频在线观看| 久久av在线看| 欧美黄色片视频| 欧美激情区在线播放| 国产va免费精品高清在线| 精品久久久久久久久中文字幕| 在线观看中文字幕亚洲| 中文字幕日韩专区| 亚洲网址你懂得| 国产一级揄自揄精品视频| 欧美日韩国产综合视频在线观看中文| 国产精品美乳在线观看| 欧美大码xxxx| 少妇高潮 亚洲精品| 欧美成人黑人xx视频免费观看| 国产精品夜色7777狼人| 91av在线免费观看| 久久五月天色综合| 欧美成人午夜激情| 色偷偷噜噜噜亚洲男人的天堂| 欧美另类精品xxxx孕妇| 成人综合国产精品| 欧美中文在线视频| 成人免费直播live| 亚洲国产婷婷香蕉久久久久久| 91国内在线视频| 欧美日韩在线视频观看| 久久久久久久久久婷婷| 大量国产精品视频| 国产美女搞久久| 九九热r在线视频精品| 国产v综合v亚洲欧美久久| 欧美性理论片在线观看片免费| 国产精品情侣自拍| 亚洲人精品午夜在线观看| 国产精品爱久久久久久久| 国产精品小说在线| 国产精品wwwwww| 欧美午夜xxx| 国产精品第一视频| 亚洲男人的天堂在线| 国产精品久久91| 亚洲国产精品yw在线观看| 久久精品视频亚洲| 精品美女久久久久久免费| 日韩欧美国产骚| 92国产精品视频| 色婷婷久久一区二区| 亚洲国产精品va在线观看黑人| 欧美日韩成人网| 日韩欧美成人区| 久久精品2019中文字幕| 欧美日韩免费看| 欧美成人久久久| 亚洲黄色在线看| 亚洲最新中文字幕| 久久免费观看视频| 成人97在线观看视频| 精品国产老师黑色丝袜高跟鞋| 色噜噜国产精品视频一区二区| 国产精品日韩欧美| 国内精品久久久久伊人av| 精品欧美一区二区三区| 国产精品欧美在线| 欧美有码在线视频| 欧美成人精品在线播放| 亚洲另类图片色| 中文字幕亚洲图片| 中文字幕视频一区二区在线有码| 日韩av三级在线观看| 久久影视电视剧免费网站清宫辞电视| 国产一区二区三区丝袜| 中文字幕无线精品亚洲乱码一区| 亚洲va欧美va在线观看| 国产精品免费一区豆花| 日韩精品高清视频| 亚洲电影成人av99爱色| 亚洲毛片在线观看.| 欧美日韩亚洲成人| 亚洲自拍小视频| 色妞色视频一区二区三区四区| 国产盗摄xxxx视频xxx69| 亚洲欧美日韩天堂一区二区| 午夜精品一区二区三区在线| 亚洲欧美综合v| 菠萝蜜影院一区二区免费| 久久久中文字幕| 欧美一级免费看| 精品无人区太爽高潮在线播放| 欧美黄色片在线观看| 国产免费一区二区三区在线观看| 欧美xxxwww| 在线成人激情黄色| 亚洲最大成人免费视频| 欧美精品久久一区二区| 91在线视频免费| 日韩精品视频在线观看免费| 欧美成人在线影院| 日韩av一区二区在线| 538国产精品视频一区二区| 黄网动漫久久久| 日本一区二区在线免费播放| 亚洲精品xxx| 97视频在线观看视频免费视频| 国产精品亚洲网站| 国产精品日韩电影| 亚洲精品乱码久久久久久金桔影视| 日韩欧美精品免费在线| 国产午夜精品久久久| 日韩免费在线看| 国产精品入口夜色视频大尺度| 欧美裸体xxxxx| 亚洲激情在线观看视频免费| 国产欧美精品一区二区| 一区二区欧美日韩视频| 91麻豆国产精品| 91av在线网站| 成人激情视频小说免费下载| 亚洲美女福利视频网站| 欧美在线欧美在线| 成人福利网站在线观看| 亚洲在线视频观看| 日韩一区二区三区在线播放| 国产精品欧美日韩一区二区| 中日韩美女免费视频网站在线观看| 亚洲精品国产电影| 国产在线视频一区| 最新69国产成人精品视频免费| 亚洲人成网站色ww在线| 色yeye香蕉凹凸一区二区av| 国精产品一区一区三区有限在线| 亚洲高清免费观看高清完整版|