設計java

          j2ee輕量級框架,IMVC,IORM && web網絡游戲

          2008年8月5日 #

          抽取最小的jre--BuildJre項目開啟

              java在桌面軟件的失利,很大程度上取決與她運行環境的陪著復雜度,還有隨時帶的一個龐大的jre環境。有時候我們并不需要jre中全部的類庫支持,我們只需要一些對我們項目有用的類庫,能否有一種通用的方法來抽取jre中的這些對我們有用的部分呢?google了下找到了幾篇文章介紹這個的。主要就是用verbose參數運行jar,然后觀察java載入了多少java類,然后手動或者寫個程序自動的吧這些類打包和jvm打包為一個全新的jre環境。這種方法是可行的,但是卻是不通用,而且這種方法還有一個很大的弊端,當有些類導入到我們項目中,但是在verbose的時候沒有用到(比如一些異常類),我們就不會導入,最終可能在發布運行的時候就用到了,這樣可不妙。那么是否還有其他方法來瘦身jre環境呢,然后通過隨身附帶jre發布java程序?答案一定是有的,我已經著手在開發這個應用,我把她起名為BuildJre。
              一,可行性分析(我們加上在win系統下):
                 java.exe是java運行的一個入口程序,當我們鍵入明了 java className的時候,首先啟動都是這個程序,然后這個程序回去查找可用的jre庫,一般是先搜索本目錄和父親目錄,如果接著搜索環境變量,判斷是否為jre的依據是,首先java.exe查找懷疑目錄(比如父目錄)的bin下有沒有java.dll,如果找到,那么他就判定這個是jre目錄然后查找lib\i386下的jvm.cfg,最后更具這里面的參數去啟動bin\client或者bin\server下的jvm.dll,這個才是真正的java虛擬機,到這里,java.exe把控制權全部交給jvm,然后jvm就初始化,分配內存等,運行程序了,運行程序期間導入的jdk包,都在jre目錄下的lib\rt.jar下。
                 說道這里,我們發現,其實不用環境變量,只要有jre環境就能運行java程序,這使得我們更加堅定java程序也可以桌面化,因為他也是可以不用配置那么麻煩的環境變量直接運行的。再回到瘦身來,剛才說了,jdk中所有的以來包全部位于jre\lib\rt.jar下,我們要廋的就是這個,40多M的rt,我們通過類依賴抽取,對于一個普通的java程序,預計可以廋到小于10M,然后配合java.exe,java.dll,等幾個小的程序,預計目標是平均廋身到15M以內。

              二,實施思路,用verbose方法不通用,不能在程序內部抽取jre,而且還有可能遺漏依賴項,不足提倡。我們架設有一個標志的依賴說明庫,比如ArrayList這個類依賴的所有包都一一對應,那么我們如果在程序里import ArrayList的話,那么我們可以迅速抽取相關的依賴包,然后在整個項目的所有import中去重復,不就ok了?現在的問題在于:
                    1,不是所有的jdk包都需要import的,比如java.lang下就不用import
                    2,有些jdk內部類在同一個包下不用寫import也一樣依賴。
                    3,計算jdk內部依賴估計要很長實踐,因為文件很多,依賴很復雜。
              這些問題基本上都有解決方法,我已經開始著手解決。

              希望有一天,我們的java項目發布,只要帶上10M的小型環境,也不用配置環境變量,雙擊,ok。。哈哈

          posted @ 2008-08-05 20:59 剎那 閱讀(2038) | 評論 (2)編輯 收藏

          主站蜘蛛池模板: 苍梧县| 白河县| 信宜市| 三台县| 赤峰市| 璧山县| 斗六市| 高密市| 邵阳县| 罗田县| 遂川县| 濉溪县| 吉林市| 杭锦后旗| 老河口市| 上饶市| 祁门县| 普兰店市| 斗六市| 龙川县| 牙克石市| 镇坪县| 望城县| 西青区| 吉首市| 龙胜| 长宁区| 金堂县| 景泰县| 武穴市| 腾冲县| 泽普县| 嵊州市| 老河口市| 历史| 承德市| 都安| 尼玛县| 皮山县| 黄陵县| 思南县|