您好,登錄后才能下訂單哦!
小編給大家分享一下如何從Java程序中調用其它程序,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!
Rmi (Remote Method Invocation,遠程方法調用)如何用于程序間通訊,另一個用于通訊的技術是Runtime.exec() 方法。你可以用這個方法從一個運行阿java程序中調用另一個程序。Runtime.exec 也允許你執行和程序相關的操作,例如控制程序的標準輸入輸出,等待程序的結束并得到它的退出狀態。下面是一個簡單的C程序,用來說明這些特性:
XML:namespace prefix = o ns = "urn:schemas-microsoft-com:Office:office" />
#include
int main() {
printf("testingn");
return 0;
}
這個程序寫字符串"testing"到標準輸出,然后用退出狀態0終止程序。
為了在java程序中執行這個簡單的程序,先編譯這個c程序:
$ cc test.c -o test
(譯者注:對于Linux用戶,可以用gcc test.c –o test,對應windows用戶可以用相應的c語言編譯程序編譯成可執行程序test.exe)
(你的 C 編譯器可能要求不同的參數)然后使用下面的代碼調用那個程序:
import java.io.*;
import java.util.ArrayList;
public class ExecDemo {
static public String[] runCommand(String cmd)
throws IOException {
// set up list to capture command output lines
ArrayList list = new ArrayList();
// start command running
Process proc = Runtime.getRuntime().exec(cmd);
/**譯者注:前面的聲明應該改成java.lang.Process,即:
java.lang.Process proc = Runtime.getRuntime().exec(cmd);
如果不改的話可能編譯不同通過,在譯者的機器上使用jdk1.2,編譯出現5個錯誤
使用jdk1.4編譯出現4個錯誤
*/
// get command's output stream and
// put a buffered reader input stream on it
InputStream istr = proc.getInputStream();
BufferedReader br =
new BufferedReader(new InputStreamReader(istr));
// read output lines from command
String str;
while ((str = br.readLine()) != null)
list.add(str);
// wait for command to terminate
try {
proc.waitFor();
}
catch (InterruptedException e) {
System.err.println("process was interrupted");
}
// check its exit value
if (proc.exitValue() != 0)
System.err.println("exit value was non-zero");
// close stream
br.close();
// return list of strings to caller
return (String[])list.toArray(new String[0]);
}
public static void main(String args[]) throws IOException {
try {
// run a command
String outlist[] = runCommand("test");
// display its output
for (int i = 0; i < outlist.length; i++)
System.out.println(outlist[i]);
}
catch (IOException e) {
System.err.println(e);
}
}
}
演示程序調用方法runCommand 實際運行程序。
String outlist[] = runCommand("test");
這個方法使用一個輸入流鉤取程序的輸出流,因此它可以讀取程序的輸出,然后將之存入一個字符串列表。
InputStream istr = proc.getInputStream();
BufferedReader br =
new BufferedReader(new InputStreamReader(istr));
String str;
while ((str = br.readLine()) != null)
list.add(str);
在所有的輸出都被讀取后,調用waitFor 等待程序終止,然后調用exitValue 讀取程序的退出狀態值。如果你做過很多系統編程的話,例如unix系統調用,這個方法你應該很熟悉。(這個例子假設當前路徑包含在你的shell的執行路徑上)。
如果你使用UNIX系統,你可以用:
runCommand("ls -l");
代替:
runCommand("test");
(譯者注:一個更為通用的就是runCommand("java");,譯者使用runCommand("dir");在Windows2000下得到的結果是程序IO異常,在linux系統下沒有測試過。)
得到當前路徑下的所有文件的長列表。但是用這個辦法得到列表突出了使用Runtime.exec 的一個基本的弱點――你調用的程序變成不可移植的。也就是說,Runtime.exec 是可移植的,在不同的java實現中都存在,但是被調用程序不一定是這樣的,在Windows系統下沒有程序叫"ls" 。
假設你運行windows NT 而你決定使用
runCommand("dir");
糾正這個問題,"dir" 是"ls" 的等同的命令。這不能工作,因為"dir" 不是一個可執行程序。它內建于shell (命令解釋器) CMD.EXE。因此你應當使用:
runCommand("cmd /c dir");
這里 "cmd /c command" 是 "調用shell 并執行指定的命令并退出。" 類似的,對于一個UNIX shell ,例如Korn shell,你可能應該用:
runCommand("ksh -c alias");
這里 "alias" 是shell 的內建命令。在這個情況下的輸出是shell 的別名的列表。
在上面獲取目錄列表的例子中,你可以用可移植的java程序到達相同的結果。例如:
import java.io.File;
public class DumpFiles {
public static void main(String args[]) {
String list[] = new File(".").list();
for (int i = 0; i < list.length; i++)
System.out.println(list[i]);
}
}
給出當前目錄下所有文件和目錄的列表。因此在大多情況下,使用ls/dir 可能沒有意義。
使使用Runtime.exec有意義的一個情況就是允許用戶指定一個編輯器或者文字處理程序(就像Emacs 或者 Vi 或者word) 編輯文件。這是大型程序的一個通常的特性。程序將有一個配置文件指定編輯器的本地路徑,然后使用這個路徑調用Runtime.exec。
Runtime.exec 的一個微妙的地方就是它如何查找文件。例如,你使用:
Runtime.exec("ls");
那么"ls" 如何被找到呢?在JDK 1.2.2 上的試驗表明是搜索PATH 環境變量。這就像你在shell中執行命令時所發生的情況。但是文檔中并沒有說明這點,因此應該小心使用。你不能假設搜索路徑已經設置。就像上面討論的那樣在有限的方式上使用Runtime.exec 可能更有意義,使用絕對路徑。
也有不同的Runtime.exec 允許你指定環境字符串數組。
以上是“如何從Java程序中調用其它程序”這篇文章的所有內容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內容對大家有所幫助,如果還想學習更多知識,歡迎關注億速云行業資訊頻道!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。