JAVA中執行DOS命令分析

下面是一種比較典型的程序模式:

  ...   Process process = Runtime.getRuntime().exec(".\p.exe");   process.waitfor( );   ...   在上面的程序中,第一行的「.\p.exe」是要執行的程序 名,Runtime.getRuntime()返回當前應用程序的Runtime對象,該對象的exec()方法指示Java虛擬機建立一個子進程執行指 定的可執行程序,並返回與該子進程對應的Process對象實例。經過Process能夠控制該子進程的執行或獲取該子進程的信息。第二條語句的目的等待 子進程完成再往下執行。   但在windows平臺上,若是處理不當,有時並不能獲得預期的結果。下面是筆者在實際編程中總結的幾種須要注意的狀況:   一、執行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虛擬機則會報運行時錯誤。前一種方法要保證程序的可移植性, 須要在程序中讀取運行的操做系統平臺,以調用不一樣的命令解釋器。後一種方法則不須要作更多的處理。   二、打開一個不可執行的文件   打開一個不可執行的文件,但該文件存在關聯的應用程序,則能夠有兩種方式。 以打開一個word文檔a.doc文件爲例,Java中能夠有如下兩種寫法:   exec("start .\a.doc");   exec(" c:\Program Files\Microsoft Office\office\winword.exe .\a.doc");   顯然,前一種方法更爲簡捷方便。   三、執行一個有標準輸出的DOS可執行程序   在 windows平臺上,運行被調用程序的DOS窗口在程序執行完畢後每每並不會自動關閉,從而致使Java應用程序阻塞在waitfor( )。致使該現象的一個可能的緣由是,該可執行程序的標準輸出比較多,而運行窗口的標準輸出緩衝區不夠大。解決的辦法是,利用Java提供的Process 類提供的方法讓Java虛擬機截獲被調用程序的DOS運行窗口的標準輸出,在waitfor()命令以前讀出窗口的標準輸出緩衝區中的內容。一段典型的程 序以下:   01....   02.String ls_1;   03.Process process = Runtime.getRuntime().exec("cmd /c dir \windows");   04.BufferedReader bufferedReader = new BufferedReader(
  05.new InputStreamReader(process.getInputStream());   06.while ( (ls_1=bufferedReader.readLine()) != null)   07.System.out.println(ls_1);   08.process.waitfor( );   09....   以上內容爲轉載~下面內容爲原創!   今天在作客戶端程序的自動更新,簡單描述一下,就是從服務器上將更新包下載下來,而後在本地解壓縮,最後刪掉~功能很簡單~   可是問題出在使用JAVA的ZIP模塊作文件的解壓縮不是想象的那麼簡單,資源須要釋放,一個不當心就沒有辦法刪除掉原有ZIP文件了~資源的 佔用確實是個大問題,可是好在,客戶端程序更新完是要重啓的,一切都煙消雲散了~對於刪除不掉ZIP文件的問題,我也流氓一下~用DEL硬刪除~此處必定 要注意!   Process process = Runtime.getRuntime().exec("cmd /c del f:\aaa.doc");   這樣的調用是沒有問題~   Process process = Runtime.getRuntime().exec("del f:\aaa.doc");   這樣寫是不可能對的編程

相關文章
相關標籤/搜索