0

別のJREを使用しているため、プロセスビルダーを使用して別のJavaプログラムを呼び出す必要があるJavaプログラムに取り組んでいます。

このプログラムを呼び出して正しく動作するバッチプログラムは次のとおりです。

cd C:\apps\Project_name\bin\
C:\Progra~1\Java\jre1.6.0_03\bin\java -Xms512m -Xmx1024m
     -cp ../lib/spring-1.2.2.jar;../lib/log4j-1.2.8.jar;../lib/commons-logging-1.0.4.jar;../lib/wrapper.jar
     com.project.main.MainProgramLauncher arg1 arg2

今、私は自分のコードを次のように宣言しました:

ProcessBuilder builder = new ProcessBuilder(
    "java",
    "-Xms512m",
    "-Xmx1024m",
    "-cp ../lib/spring-1.2.2.jar;../lib/log4j-1.2.8.jar;"+
    "../lib/commons-logging-1.0.4.jar;../lib/wrapper.jar",
    "com.project.main.MainProgramLauncher arg1 arg2 ...argN"
);
Map<String, String> environment = builder.environment();

environment.put("path", ";"); // Clearing the path variable;
environment.put("path", java_bin_location+";");
Process javap = builder.start();
InputStreamReader tempReader = new InputStreamReader(
    new BufferedInputStream(javap.getInputStream())
);
BufferedReader reader = new BufferedReader(tempReader);
while (true) {
    String line = reader.readLine();
    if (line == null)
        break;
    System.out.println(line);
}

しかし、それは本来あるべき方法で実行されていません。プログラムがすぐにクラッシュします。私がやるべきことは何か違うのですか?提案してください。

4

1 に答える 1

1

クラス名とパラメータを別の文字列にする必要があると思います。それ以外の:

"java",
"-Xms512m",
"-Xmx1024m",
"-cp ../lib/spring-1.2.2.jar;../lib/log4j-1.2.8.jar;"+
"../lib/commons-logging-1.0.4.jar;../lib/wrapper.jar",
"com.project.main.MainProgramLauncher arg1 arg2 ...argN"

そのはず

"java",
"-Xms512m",
"-Xmx1024m",
"-cp",
"../lib/spring-1.2.2.jar;../lib/log4j-1.2.8.jar;"+
"../lib/commons-logging-1.0.4.jar;../lib/wrapper.jar",
"com.project.main.MainProgramLauncher",
"arg1",
"arg2",
...
"argN"

を呼び出すためにフルパス名を使用したが、を使用しjava.exeた場合には使用しなかったもう1つの注目すべき点ProcessBuilder

エラーストリームを読み取ることもできます(または呼び出しredirectErrorStream(true)-引数は重要です(!))。

于 2010-01-21T02:34:49.313 に答える