通过Process可以控制该子进程的执行或获取该子进程的信息。第二条语句的目的等待 子进程完成再往下执行。 但在windows平台上,如果处理不当,有时并不能得到预期的结果。下面是笔者在实际编程中总结的几种需要注意的情况: 1、执行DOS的内部
命令 如果要执行一条DOS内部命令,有两种方法。一种方法是把命令解释器包含在exec()的参数中。例如,执行dir命令,在NT上,可写成 exec("cmd.exe /c dir"),在windows 95/98下,可写成“command.exe /c dir”,其中参数“/c”表示命令执行后关闭Dos立即关闭窗口。另一种方法是,把内部命令放在一个批命令my_dir.bat
文件中,在Java
程序 中写成exec("my_dir.bat")。如果仅仅写成exec("dir"),Java虚拟机则会报运行时错误。前一种斗兆方法要保证程序的可移植性, 需要在程序中读取运行的 *** 作系统平台,以调用不同的命令解释器。后一种方法则不需要做更多的处理。 2、打开一个不可执行的文件 打开一个不可执行的文件,但该文件存在关联的应用程序,则可以有两种方式。 以打开一个word文档a.doc文件为例,Java中可以有以下两种写法: exec("start .a.doc")exec(" c:Program FilesMicrosoft Officeofficewinword.exe .a.doc")显然,前一种方法更为简捷方便。 3、执行一个有标准输出的DOS可执行程序 在windows平台上扒姿,运行被调用程序的DOS窗口在程序执行完毕后往往并不会自动关闭,从而导致Java应用程序阻塞在waitfor( )。导致该现象的一个可能的原因是,该可执行程序的标准输出比较多,而运行窗口的标准输出缓冲区不够大。解决的办法是,利用Java提供的Process 类提供的方法让Java虚拟机截获被调用程序的DOS运春销绝行窗口的标准输出,在waitfor()命令之前读出窗口的标准输出缓冲区中的内容。一段典型的程 序如下: ... String ls_1Process process = Runtime.getRuntime().exec("cmd /c dir windows")BufferedReader bufferedReader = new BufferedReader( new InputStreamReader(process.getInputStream())while ( (ls_1=bufferedReader.readLine()) != null) System.out.println(ls_1)process.waitfor( )... 以上内容为转载~下面内容为原创! 今天在做客户端程序的自动更新,简单描述一下,就是从服务器上将更新包下载下来,然后在本地解压缩,最后删掉~功能很简单。 但是问题出在使用JAVA的ZIP模第一:首先安装JDK。
第二:为了能使Java程序在dos下很方便的编译和运行Java程序,就要配置其运
行的环境变量,具体步骤如下:
(1)在安装的目录下找到你所安装的JDK文件,在里面找到java.exe文件,复制其路径。
(2)鼠标右击我的电脑,渗族洞打开属性面板单击高级菜单、选择“环境变量”。
(3) 在d出的面板中找到“系统环境变量”,在其窗口选中变量名为Path的变量。
Path是路径设置命令,其功能是:设备可执行文件的搜索路径,丛枯只对文件有效。当运行一个可执行文件时,DOS会先在当前目录中搜索该文件,若找到则运行之;若找不到该文件,则根据Path命令所设置的路径,顺序逐条地到目录中搜索该文件;Path命令中的路径,若有两条以上,各路径之间以一个分号“;”开。
(4)单击“编辑”,在d出的窗口中的变量值的最后面粘贴上你刚才找到的路径,中间用分号隔开,单击确定。这样你就可以在DOS下很轻松的编译和运行Java程序.
如果Path路径中前面的路径有别的JDK版本,则在DOS下运行的是路径比较前面的版本。
第穗态三:编译Java程序生成“.class”文件,在DOS下,应用DOS命令找到你所编Java程序文件(假设文件名为HelloWorld.java)的根目录下输入命令:javac
HelloWorld.java。如果生成。“.class”文件则编译成功。
第四:执行Java程序:接着上步 *** 作输入:java HelloWorld;在命令提示符上会出现运行结果。
评论列表(0条)