﻿<?xml version="1.0" encoding="utf-8" standalone="yes"?><rss version="2.0" xmlns:dc="http://purl.org/dc/elements/1.1/" xmlns:trackback="http://madskills.com/public/xml/rss/module/trackback/" xmlns:wfw="http://wellformedweb.org/CommentAPI/" xmlns:slash="http://purl.org/rss/1.0/modules/slash/"><channel><title>BlogJava-龙人嵌入式系统开发和ODM研发-文章分类-java技术文章</title><link>http://www.blogjava.net/armodmlr/category/29808.html</link><description>龙人嵌入式系统开发和ODM研发—arm9开发板和arm7开发板</description><language>zh-cn</language><lastBuildDate>Sat, 01 Mar 2008 08:41:50 GMT</lastBuildDate><pubDate>Sat, 01 Mar 2008 08:41:50 GMT</pubDate><ttl>60</ttl><item><title>让Java程序带着JRE一起上路</title><link>http://www.blogjava.net/armodmlr/articles/183143.html</link><dc:creator>龙人嵌入式开发</dc:creator><author>龙人嵌入式开发</author><pubDate>Sat, 01 Mar 2008 07:47:00 GMT</pubDate><guid>http://www.blogjava.net/armodmlr/articles/183143.html</guid><wfw:comment>http://www.blogjava.net/armodmlr/comments/183143.html</wfw:comment><comments>http://www.blogjava.net/armodmlr/articles/183143.html#Feedback</comments><slash:comments>0</slash:comments><wfw:commentRss>http://www.blogjava.net/armodmlr/comments/commentRss/183143.html</wfw:commentRss><trackback:ping>http://www.blogjava.net/armodmlr/services/trackbacks/183143.html</trackback:ping><description><![CDATA[<p>用Java开发程序，发布时总要考虑的问题就是怎么在使用者的机器上装好JRE。要考虑的问题很多：使用者有没有能力独自安装JRE，使用者已有的JRE和我们需要的版本是不是一致，会不会出现版本问题，等等。<br />
<br />
　　使用.NET要考虑的问题就少些。现在.NET CLR似乎已经很普及了，看好多D版的Win XP都会自己安装最新的.NET CLR，而且似乎它的安装界面也比JRE友好些。彻底解决安装JRE的问题的方案，就是让我们的应用程序自己背着JRE！这样，我们的程序就像传统的Win32应用程序一样，双击就可以执行，不用管所在的机器上是否有JRE，是什么版本的JRE，无论怎样，我有我自己的！要做到这一点，其实非常容易。<br />
<br />
　　王森在他的《Java深度历险》（强力推荐这本书，内容少而精）的第一章就解释了JDK，JRE，JVM之间的关系。解释了我们执行java.exe时发生的事情。其中提到，java.exe依照一套逻辑来寻找可以用的JRE，首先查找自己所在的目录下有没有JRE（据王森讲这样说不确切，我没有JDK全部的源代码，在此无从考证）；其次查找自己的父目录下有没有JRE；最后才是查询Windows的注册表。<br />
<br />
　　通常我们在安装好了JRE的机器上的任何一个目录下都可以执行java.exe。因为它在安装时被复制到了windows的system32目录下，而后者无论如何都会在path环境变量中。这个java.exe最终必然会访问注册表来确定真正的JRE的所在地。若我们要求每一个应用程序都自带JRE，必然不能走这条路。但，逻辑的第二条讲，java.exe会在它的父目录下查找JRE，解决方案就在这一条中。<br />
假设我们的应用程序打好了包，叫做MyApp.jar，放在MyApp的目录下。我们在MyApp目录下，可以执行java &#8211;jar MyApp.jar来运行我们的程序。我们安装的是JRE 1.5，在C:\Program Files\Java\jre1.5.0下。现在，我们只需要简单的将jre1.5.0目录搬到MyApp目录下，顺便改个容易写的名字比如叫jre。现在，我们的应用程序就象这样：<br />
<br />
　　MyApp<br />
　　MyApp.jar<br />
　　Jre<br />
　　Jre1.5.0目录下的全部内容<br />
<br />
　　Java.exe就在jre目录下的bin目录中。根据第二条逻辑，java.exe会在它的父目录中查找jre，实验证实，它会查找lib目录，而lib就在jre目录下。因此，这样java.exe就会确定jre的所在然后正常执行java程序，不会去管我们是否安装了JRE，注册表中是否有注册项这些杂事了。<br />
<br />
　　试一下，在命令行下进入MyApp的目录下，假设它在C盘，将path指向MyApp下的JRE：<br />
　　set path=c:\MyApp\jre\bin<br />
<br />
　　然后运行：<br />
　　java &#8211;verbose &#8211;jar MyApp.jar<br />
<br />
　　加上verbose参数以确定我们确实用了这一套被搬出了家的JRE。程序可以运行，并且在命令行输出的前几行，可以看到：<br />
<br />
　　[Opened C:\MyApp\jre\lib\rt.jar]<br />
　　[Opened C:\MyApp\jre\lib\jsse.jar]<br />
　　[Opened C:\MyApp\jre\lib\jce.jar]<br />
　　[Opened C:\MyApp\jre\lib\charsets.jar]<br />
<br />
　　因此程序读取的确实是它的私有的JRE。<br />
至此，我们似乎完成了任务。但是现在我们的私有JRE仍不完美，缺点是太大。JRE 1.5有接近70MB，作为我们的私有的JRE，好多内容都是可以抛弃的。Jre目录下的license都可以不要，bin下的执行文件只需要保留java.exe或者javaw.exe，lib下只要保留rt，jsse，jce，charsets几个库就可以了。除了i386和zi两个子目录外，其余的子目录都可以不要。Zi下只需要保留自己地区的子目录和其下的一些文件就可以。Lib下除了库之外的属性文件等等都要保留。这样清理一番，JRE仍然有接近50MB。还可以继续清理几个库文件里面不需要的内容，这需要仔细的整理，会很费功夫。最好能写出一个自动工具帮助我们整理它们。从Sun公司上下到的JMF里面附带的用Java写的媒体播放器就自带了JRE，只有几个MB。<br />
<br />
　　清理过后需要运行几遍我们的应用程序，以确保我们的JRE不缺少东西。
<p>&nbsp;</p>
<p>　　如果我们希望能有一个程序直接启动我们的应用程序，那就还要费些功夫。最简单的方法是弄出一个快捷方式来，但是快捷方式的路径不能是相对的，不方便我们安装。我想到的方案就是用Win32程序包装一下。在VS.NET下写一个Win32小程序：（点击查看<a href="http://www.pconline.com.cn/pcedu/empolder/gj/java/0509/acc/05-09-16-jre.txt">附件</a>）<br />
<br />
　　基本上是按照MSDN文档中的例子照搬的。将它编译成一个EXE文件，我们的任务才全部完成。双击这个EXE文件，我们的程序启动了，看起来和传统的Win32程序没有两样，JRE完全被隐藏在底层。<br />
<br />
　　P.S. 使用了这个方案后，我用Wise Installation System制作安装程序，发现一个非常奇怪的问题，安装结束后，安装程序似乎非要运行一个叫做GLJ什么什么，后缀是TMP的程序，还需要JVM，结果就报错JVM.DLL找不到。安装总是不成功。我已经禁掉了OCX / DLL / EXE自注册和卸载支持，为什么还不对？有谁知道是为什么吗？ </p>
<img src ="http://www.blogjava.net/armodmlr/aggbug/183143.html" width = "1" height = "1" /><br><br><div align=right><a style="text-decoration:none;" href="http://www.blogjava.net/armodmlr/" target="_blank">龙人嵌入式开发</a> 2008-03-01 15:47 <a href="http://www.blogjava.net/armodmlr/articles/183143.html#Feedback" target="_blank" style="text-decoration:none;">发表评论</a></div>]]></description></item></channel></rss>